當前位置: 首頁>>代碼示例>>Python>>正文


Python functions.count方法代碼示例

本文整理匯總了Python中sqlalchemy.sql.functions.count方法的典型用法代碼示例。如果您正苦於以下問題:Python functions.count方法的具體用法?Python functions.count怎麽用?Python functions.count使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在sqlalchemy.sql.functions的用法示例。


在下文中一共展示了functions.count方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_logging_in_creates_user_no_https

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def test_logging_in_creates_user_no_https(self):
        dokomoforms.handlers.demo.options.https = False
        no_user = (
            self.session
            .query(count(Administrator.id))
            .filter_by(name='demo_user')
            .scalar()
        )
        self.assertEqual(no_user, 0)
        self.fetch('/demo/login', _logged_in_user=None)
        user = (
            self.session
            .query(count(Administrator.id))
            .filter_by(name='demo_user')
            .scalar()
        )
        self.assertEqual(user, 1) 
開發者ID:SEL-Columbia,項目名稱:dokomoforms,代碼行數:19,代碼來源:test_demo_mode.py

示例2: test_logging_in_creates_user_https

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def test_logging_in_creates_user_https(self):
        dokomoforms.handlers.demo.options.https = True
        no_user = (
            self.session
            .query(count(Administrator.id))
            .filter_by(name='demo_user')
            .scalar()
        )
        self.assertEqual(no_user, 0)
        self.fetch('/demo/login', _logged_in_user=None)
        user = (
            self.session
            .query(count(Administrator.id))
            .filter_by(name='demo_user')
            .scalar()
        )
        self.assertEqual(user, 1) 
開發者ID:SEL-Columbia,項目名稱:dokomoforms,代碼行數:19,代碼來源:test_demo_mode.py

示例3: test_get_logged_in_admin

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def test_get_logged_in_admin(self):
        num_surveys = (
            self.session
            .query(count(models.Survey.id))
            .filter_by(creator_id='b7becd02-1a3f-4c1d-a0e1-286ba121aef4')
            .scalar()
        )
        response = self.fetch('/', method='GET')
        response_soup = BeautifulSoup(response.body, 'html.parser')
        links = response_soup.select('a.btn-login.btn-large')
        self.assertEqual(len(links), 0, msg=response.body)
        self.assertIn(
            'Account Overview', response.body.decode(), msg=response.body
        )
        survey_dropdown = (
            response_soup.find('ul', {'aria-labelledby': 'SurveysDropdown'})
        )
        self.assertEqual(
            len(survey_dropdown.findAll('li')),
            min(num_surveys, BaseHandler.num_surveys_for_menu),
            msg=survey_dropdown
        ) 
開發者ID:SEL-Columbia,項目名稱:dokomoforms,代碼行數:24,代碼來源:test_handlers.py

示例4: test_login_success

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def test_login_success(self):
        dokomoforms.handlers.auth.options.https = False
        with patch.object(handlers.Login, '_async_post') as p:
            dummy = lambda: None
            dummy.body = json_encode(
                {'status': 'okay', 'email': 'test_creator@fixtures.com'}
            )
            p.return_value = tornado.gen.Task(
                lambda callback=None: callback(dummy)
            )
            response = self.fetch(
                '/user/login?assertion=woah', method='POST', body='',
                _logged_in_user=None
            )
        self.assertEqual(response.code, 200, msg=response.body)
        self.assertEqual(
            response.headers['Set-Cookie'].lower().count('secure'),
            1
        ) 
開發者ID:SEL-Columbia,項目名稱:dokomoforms,代碼行數:21,代碼來源:test_handlers.py

示例5: tag_counts

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def tag_counts(self):
        """ Return a list of counts for the tags this project has.

        [('arcade', 2), ('opengl', 1)]
        """

        tags = [t.value for t in self.tags]
        cnt = count(Tags.value)

        tag_counts = (inspect(self).session
                      .query(Tags.value, cnt)
                      .group_by(Tags.value)
                      .filter(Tags.value.in_(tags))
                      .order_by(cnt.desc())).all()
        return [(tag, cnt, (int(10 + min(24, sqrt(cnt) * 24 / 5))))
                for tag, cnt in tag_counts] 
開發者ID:pygame,項目名稱:pygameweb,代碼行數:18,代碼來源:models.py

示例6: _delete_time_range

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def _delete_time_range(self, s, start, finish):
        composite_ids = s.query(Composite.id). \
            join(StatisticJournal, Composite.id == StatisticJournal.source_id). \
            join(StatisticName, StatisticJournal.statistic_name_id == StatisticName.id). \
            filter(StatisticName.owner == self.owner_out)
        if start:
            composite_ids = composite_ids.filter(StatisticJournal.time >= start)
        if finish:
            composite_ids = composite_ids.filter(StatisticJournal.time <= finish)
        log.debug(f'Delete query: {composite_ids}')
        n = s.query(count(Source.id)). \
            filter(Source.id.in_(composite_ids)). \
            scalar()
        if n:
            log.warning(f'Deleting {n} Composite sources ({start} - {finish})')
            s.query(Source). \
                filter(Source.id.in_(composite_ids)). \
                delete(synchronize_session=False)
            s.commit() 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:21,代碼來源:monitor.py

示例7: _delete

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def _delete(self, s):
        start, finish = self._start_finish(type=local_time_to_time)
        s.commit()   # so that we don't have any risk of having something in the session that can be deleted
        statistic_names = s.query(StatisticName.id).filter(StatisticName.owner == self.owner_out)
        activity_journals = self._delimit_query(s.query(self._journal_type.id))
        statistic_journals = s.query(StatisticJournal.id). \
            filter(StatisticJournal.statistic_name_id.in_(statistic_names.cte()),
                   StatisticJournal.source_id.in_(activity_journals))
        for repeat in range(2):
            if repeat:
                s.query(StatisticJournal).filter(StatisticJournal.id.in_(statistic_journals.cte())). \
                    delete(synchronize_session=False)
                Timestamp.clear_keys(s, activity_journals.cte(), self.owner_out, constraint=None)
            else:
                n = s.query(count(StatisticJournal.id)). \
                    filter(StatisticJournal.id.in_(statistic_journals.cte())).scalar()
                if n:
                    log.warning(f'Deleting {n} statistics for {long_cls(self.owner_out)} from {start} to {finish}')
                else:
                    log.warning(f'No statistics to delete for {long_cls(self.owner_out)} from {start} to {finish}')
        s.commit() 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:23,代碼來源:utils.py

示例8: _delete_from

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def _delete_from(self, s, start=None):
        composite_ids = s.query(Composite.id). \
            join(StatisticJournal, Composite.id == StatisticJournal.source_id). \
            join(StatisticName, StatisticJournal.statistic_name_id == StatisticName.id). \
            filter(StatisticName.owner == self.owner_out)
        if start:
            composite_ids = composite_ids.filter(StatisticJournal.time >= start)
        log.debug(f'Delete query: {composite_ids}')
        n = s.query(count(Source.id)). \
            filter(Source.id.in_(composite_ids)). \
            scalar()
        if n:
            log.warning(f'Deleting {n} Composite sources ({start} onwards)')
            s.query(Source). \
                filter(Source.id.in_(composite_ids)). \
                delete(synchronize_session=False)
            s.commit()
            Composite.clean(s) 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:20,代碼來源:response.py

示例9: __missing_sources

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def __missing_sources(self, s):
        log.debug('Searching for missing sources')
        available = s.query(count(distinct(Source.id))). \
            join(StatisticJournal). \
            join(StatisticName). \
            filter(StatisticName.name == self.prefix + SPACE + N.HR_IMPULSE_10)
        used = s.query(count(distinct(Source.id))). \
            join(CompositeComponent, CompositeComponent.input_source_id == Source.id). \
            join(Composite, Composite.id == CompositeComponent.output_source_id). \
            join(StatisticJournal, StatisticJournal.source_id == Composite.id). \
            join(StatisticName). \
            filter(StatisticName.owner == self.owner_out,
                   Source.type == SourceType.ACTIVITY)
        n_avaialble = available.scalar()
        n_used = used.scalar()
        log.debug(f'Using {n_used} of {n_avaialble} sources')
        return n_used != n_avaialble 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:19,代碼來源:response.py

示例10: run_pipeline

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def run_pipeline(data, type, like=tuple(), unlike=tuple(), id=None, progress=None, **extra_kargs):
    with data.db.session_context() as s:
        if id is None:  # don't run for each worker
            if type in (PipelineType.CALCULATE, PipelineType.READ_ACTIVITY, PipelineType.READ_MONITOR):
                Interval.clean(s)
        local_progress = ProgressTree(Pipeline.count(s, type, like=like, unlike=unlike, id=id), parent=progress)
        for pipeline in Pipeline.all(s, type, like=like, unlike=unlike, id=id):
            kargs = dict(pipeline.kargs)
            kargs.update(extra_kargs)
            msg = f'Ran {short_cls(pipeline.cls)}'
            if 'activity_group' in kargs: msg += f' ({kargs["activity_group"]})'
            log.debug(f'Running {pipeline.cls}({pipeline.args}, {kargs})')
            with timing(msg):
                before = None if id else count_statistics(s)
                pipeline.cls(data, *pipeline.args, id=pipeline.id, progress=local_progress, **kargs).run()
                after = None if id else count_statistics(s)
            if before or after:
                log.info(f'{msg}: statistic count {before} -> {after} (change of {after - before})') 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:20,代碼來源:pipeline.py

示例11: _read_data

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def _read_data(self, s, file_scan):
        records = self.parse_records(read_fit(file_scan.path))
        first_timestamp = self.read_first_timestamp(file_scan.path, records)
        last_timestamp = self.read_last_timestamp(file_scan.path, records)
        if first_timestamp == last_timestamp:
            log.warning('File %s is empty (no timespan)' % file_scan)
            raise AbortImportButMarkScanned()
        if not first_timestamp:
            raise Exception('Missing timestamp in %s' % file_scan)

        log.info(f'Importing monitor data from {file_scan} '
                 f'for {format_time(first_timestamp)} - {format_time(last_timestamp)}')
        if self.force:
            log.debug(f'Deleting previous entry')
            s.query(MonitorJournal).filter(MonitorJournal.file_hash == file_scan.file_hash).delete()
        else:
            if s.query(MonitorJournal).filter(MonitorJournal.file_hash == file_scan.file_hash).count():
                raise Exception(f'Duplicate for {file_scan.path}')  # should never happen
        # adding 0.1s to the end time makes the intervals semi-open which simplifies cleanup later
        mjournal = add(s, MonitorJournal(start=first_timestamp,
                                         finish=last_timestamp + dt.timedelta(seconds=0.1),
                                         file_hash_id=file_scan.file_hash.id))
        return mjournal, (first_timestamp, last_timestamp, mjournal, records) 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:25,代碼來源:monitor.py

示例12: _fix_pair

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def _fix_pair(self, s, a, b):
        # a starts before b (from query)
        if b.finish <= a.finish:
            # b completely enclosed in a
            log.warning(f'Deleting monitor journal entry that completely overlaps another')
            log.debug(f'{a.start} - {a.finish} ({a.id}) encloses {b.start} - {b.finish} ({b.id})')
            # be careful to delete superclass...
            s.query(Source).filter(Source.id == b.id).delete()
        else:
            # otherwise, shorten a so it finishes where b starts
            q = s.query(StatisticJournal). \
                filter(StatisticJournal.source == a,
                       StatisticJournal.time >= b.start)
            count = q.count()
            if count:
                # not really a warning because we expect this
                log.debug(f'Shifting edge of overlapping monitor journals ({count} statistic values)')
                log.debug(f'{a.start} - {a.finish} ({a.id}) overlaps {b.start} - {b.finish} ({b.id})')
                q.delete()
            # update monitor whether statistics were changed or not
            log.debug(f'Shift monitor finish back from {a.finish} to {b.start}')
            a.finish = b.start
            s.flush()  # not sure this is needed 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:25,代碼來源:monitor.py

示例13: _write_diff

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def _write_diff(self, s, df):
        steps = StatisticName.add_if_missing(s, T.STEPS, StatisticJournalType.INTEGER, Units.STEPS_UNITS,
                                             None, self.owner_out, description=STEPS_DESCRIPTION)
        times = df.loc[(df[NEW_STEPS] != df[N.STEPS]) & ~df[N.STEPS].isna()].index.astype(np.int64) / 1e9
        if len(times):
            n = s.query(func.count(StatisticJournal.id)). \
                filter(StatisticJournal.time.in_(times),
                       StatisticJournal.statistic_name == steps).scalar()
            log.warning(f'Deleting {n} {N.STEPS} entries')
            s.query(StatisticJournal.id). \
                filter(StatisticJournal.time.in_(times),
                       StatisticJournal.statistic_name == steps).delete(synchronize_session=False)
        loader = self._get_loader(s, owner=self.owner_out, add_serial=False)
        for time, row in df.loc[(df[NEW_STEPS] != df[N.STEPS]) & ~df[NEW_STEPS].isna()].iterrows():
            loader.add(T.STEPS, Units.STEPS_UNITS, None, row[N.SOURCE], int(row[NEW_STEPS]),
                       time, StatisticJournalInteger, description=STEPS_DESCRIPTION)
        loader.load() 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:19,代碼來源:monitor.py

示例14: missing_dates

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def missing_dates(cls, s, expected, schedule, interval_owner, statistic_owner=None, start=None, finish=None):
        '''
        Previous approach was way too complicated and not thread-safe.  Instead, just enumerate intervals and test.
        '''
        stats_start_time, stats_finish_time = cls._raw_statistics_time_range(s, statistic_owner)
        stats_start = time_to_local_date(stats_start_time)
        stats_finish = time_to_local_date(stats_finish_time)
        log.debug('Statistics (in general) exist %s - %s' % (stats_start, stats_finish))
        start = schedule.start_of_frame(start if start else stats_start)
        finish = finish if finish else schedule.next_frame(stats_finish)
        while start < finish:
            next = schedule.next_frame(start)
            existing = s.query(Interval). \
                filter(Interval.start == start,
                       Interval.schedule == schedule,
                       Interval.owner == interval_owner).count()
            if existing != expected:
                yield start, next
            start = next 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:21,代碼來源:source.py

示例15: clean

# 需要導入模塊: from sqlalchemy.sql import functions [as 別名]
# 或者: from sqlalchemy.sql.functions import count [as 別名]
def clean(cls, s):
        log.debug('Searching for invalid composites')
        # see test_recursive
        q_input_counts = s.query(Composite.id,
                                 count(CompositeComponent.input_source_id).label('count')). \
            outerjoin(CompositeComponent, CompositeComponent.output_source_id == Composite.id). \
            group_by(Composite.id).cte()
        q_bad_nodes = s.query(Composite.id). \
            join(q_input_counts, q_input_counts.c.id == Composite.id). \
            filter(Composite.n_components != q_input_counts.c.count)
        q_count = s.query(count(Composite.id)).filter(Composite.id.in_(q_bad_nodes))
        log.debug(q_count)
        if q_count.scalar():
            log.warning('Need to clean expired composite sources (may take some time)')
            q_bad_nodes = q_bad_nodes.cte(recursive=True)
            q_all_nodes = q_bad_nodes. \
                union_all(s.query(Composite.id).
                          join(CompositeComponent,
                               CompositeComponent.output_source_id == Composite.id).
                          join(q_bad_nodes,
                               CompositeComponent.input_source_id == q_bad_nodes.c.id)).select()
            log.debug(f'Executing {q_all_nodes}')
            s.flush()
            with timing('GC of composite sources'):
                s.query(Source).filter(Source.id.in_(q_all_nodes)).delete(synchronize_session=False) 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:27,代碼來源:source.py


注:本文中的sqlalchemy.sql.functions.count方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。