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


Python Game.objects方法代碼示例

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


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

示例1: join_random

# 需要導入模塊: from game.models import Game [as 別名]
# 或者: from game.models.Game import objects [as 別名]
def join_random(request):
    games = Game.objects(players__ne=request.user.username, state='playing')
    games.where('this[~num_players] < this[~max_players]')
    games.order_by('next_ending').limit(1)
    for game in games:
        request.session['join_auto'] = game.pk
        return redirect('game.views.join', game.pk)
    else:
        return render(request, 'nogames.html')
開發者ID:dcrosta,項目名稱:nymwit,代碼行數:11,代碼來源:views.py

示例2: profile

# 需要導入模塊: from game.models import Game [as 別名]
# 或者: from game.models.Game import objects [as 別名]
def profile(request, username):
    profile = get_document_or_404(User, username=username)

    current = Game.objects(players=profile.username, state__in=('playing', 'voting'))
    current.order_by('next_ending')

    past = Game.objects(players=profile.username, state__in=('invalid', 'finished')).limit(10)
    past.order_by('-next_ending')

    prefs_form = None
    # if profile == request.user:
    #     initial = PreferencesForm.initial_for(profile)
    #     prefs_form = PreferencesForm(initial=initial)

    return render(request, 'profile.html',
                  profile=profile,
                  current=current,
                  past=past,
                  prefs_form=prefs_form)
開發者ID:dblado,項目名稱:nymwit,代碼行數:21,代碼來源:views.py

示例3: index

# 需要導入模塊: from game.models import Game [as 別名]
# 或者: from game.models.Game import objects [as 別名]
 def index(self):
     form = BallotForm(request.form)
     form.game.choices = [(str(Game.objects(name=x).first().id), x) for x in Game.objects.distinct('name')]
     if request.method == 'POST' and form.validate():
         game = form.game.data
         ballot_type = form.ballot_type.data
         results = self.ballot(game, ballot_type)
         self._template_args['ballot_results'] = results
         self._template_args['round'] = self.round
     return self.render('ballot.html', form=form)
開發者ID:starschen,項目名稱:guandan,代碼行數:12,代碼來源:views.py

示例4: handle_noargs

# 需要導入模塊: from game.models import Game [as 別名]
# 或者: from game.models.Game import objects [as 別名]
 def handle_noargs(self, **options):
     games = Game.objects(state__in=('playing', 'voting'), next_ending__lte=datetime.now(utc))
     for game in games:
         if game.state == 'playing':
             if game.num_players < 2:
                 game.update(set__state='invalid')
                 log.debug('advanced game %s from playing to invalid, only %d players', game.pk, game.num_players)
             else:
                 new_next_ending = game.next_ending + timedelta(minutes=game.minutes_per_round)
                 game.update(set__state='voting', set__next_ending=new_next_ending)
                 log.debug('advanced game %s from playing to voting, next ending %s', game.pk, new_next_ending)
         elif game.state == 'voting':
             total_votes = sum(len(play.upvotes) for play in game.plays)
             if total_votes == 0:
                 game.update(set__state='invalid')
                 log.debug('advanced game %s from voting to invalid, 0 votes', game.pk)
             else:
                 game.update(set__state='finished')
             log.debug('advanced game %s from voting to finished', game.pk)
開發者ID:dblado,項目名稱:nymwit,代碼行數:21,代碼來源:advancegamestate.py

示例5: handle_noargs

# 需要導入模塊: from game.models import Game [as 別名]
# 或者: from game.models.Game import objects [as 別名]
    def handle_noargs(self, **options):
        now = datetime.now(utc)

        leaderboard = Leaderboard.objects._collection
        bookkeeping = leaderboard.bookkeeping

        # acquire the "lock" to prevent (potential) other m-r
        # jobs on leaderboard from running concurrently
        try:
            lock = bookkeeping.find_and_modify(
                query={'_id': 1, 'locked': False},
                update={'$set': {'locked': True, 'started_at': now}},
                upsert=True,
                new=True)
        except OperationFailure:
            lock = bookkeeping.find_one()
            diff = (now - lock['started_at']).seconds
            if 300 < diff and diff < 600:
                log.info("another leaderboard job running for more than 5 minutes")
            elif 600 < diff:
                log.warning("another leaderboard job running for more than 10 minutes")
            sys.exit(1)

        try:
            # find the last updated date in the leaderboard,
            # or the earliest finished game if no leaderboard
            # entries exist yet
            start = lock.get('last_update')
            if not start:
                log.debug('running first time')
                first_game = Game.objects(state='finished')
                first_game = first_game.order_by('next_ending').first()

                if first_game:
                    start = first_game.next_ending
                else:
                    start = datetime.now(utc)

            end = datetime.now(utc)

            if end > start:
                log.info('map-reduce %s to %s', start, end)
                Game.objects._collection.map_reduce(
                    map=self.map_func,
                    reduce=self.reduce_func,
                    out=leaderboard.name,
                    reduce_output=True,
                    query=Game.objects(
                        state='finished',
                        next_ending__gte=start,
                        next_ending__lt=end)._query
                )

                # iterate each week between start and
                # end, and ensure indices exist on all
                # the score fields that they should
                for d in range(0, (end - start).days + 6, 7):
                    self.ensure_indices(leaderboard, start + timedelta(days=d))
            else:
                log.info('nothing to map-reduce')

        except:
            log.exception('error during leaderboard map-reduce')

        finally:
            finish = datetime.now(utc)
            diff = finish - now
            diff = 86400 * diff.days + diff.seconds
            log.info('finished, took %ss', diff)
            bookkeeping.find_and_modify(
                query={'_id': 1},
                update={'$set': {'locked': False, 'last_update': end}})
開發者ID:dblado,項目名稱:nymwit,代碼行數:74,代碼來源:leaderboard.py


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