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


Python DBSession.query方法代碼示例

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


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

示例1: best_by_user_alias

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
    def best_by_user_alias(cls,alias):
        from quizsmith.app.models import TestsResults
        from quizsmith.app.utilities import Seconds2Str
        tests = DBSession.query(Tests,func.count(Tests.category)).filter(Tests.alias==alias).group_by(Tests.category).all()

        results = []
        for test in tests:
            best_duration = DBSession.query(Tests).filter(Tests.alias==alias).filter(Tests.category==test[0].category).filter(Tests.time_spent > 0).order_by('time_spent asc').first().time_spent
            best_scores = DBSession.query(Tests).filter(Tests.alias==alias).filter(Tests.category==test[0].category).order_by('total_competitive desc').first()
            last_played = DBSession.query(Tests).filter(Tests.alias==alias).filter(Tests.category==test[0].category).order_by('created desc').first().created
            results.append({'Test':test[0], 
                            'best_duration':Seconds2Str(best_duration), 
                            'best_percentage':round(best_scores.percentage,2), 
                            'best_competitive':int(best_scores.total_competitive), 
                            'Count':test[1], 
                            'last_played': last_played.strftime('%m/%d/%Y %I:%M %p')})
        return results
        

        
        
        
        
        
        
        
        
        
        
        
開發者ID:polklibrary,項目名稱:quizsmith,代碼行數:19,代碼來源:tests.py

示例2: get_groups

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def get_groups(self,field=None):
     from quizsmith.app.models import Groups
     if field:
         z = zip(*DBSession.query(getattr(Groups,field)).join(Users.groups).filter(Users.id==self.id).all())
         if z:
             return list(z.pop())
         return []
     return DBSession.query(Groups).join(Users.groups).filter(Users.id==self.id).all()
開發者ID:hietpasd,項目名稱:quizsmith,代碼行數:10,代碼來源:users.py

示例3: get

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def get(cls,name,default=None):
     try:
         prop = DBSession.query(Properties).filter(Properties.prop_name==name).first().prop_value
         if prop:
             return prop
         return default
     except:
         return default
開發者ID:hietpasd,項目名稱:quizsmith,代碼行數:10,代碼來源:properties.py

示例4: run

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
    def run(self):
        category = self.request.params.get('category','missing')
        
        attempts = {} #'THE_USER_NAME_HERE':1
        questions = []
        
        tests = DBSession.query(Tests).filter(Tests.category==category).filter(Tests.created>=self.start).filter(Tests.created<=self.end).order_by('created asc')
        if not self.include_incompleted:
            tests = tests.filter(Tests.completed==1)
        tests = tests.all()
        
        data = [
            {'Attempt':'1st Attempt', 'Score':0, 'Of':0},
            {'Attempt':'2nd Attempt', 'Score':0, 'Of':0},
            {'Attempt':'3rd Attempt', 'Score':0, 'Of':0},
            {'Attempt':'4th Attempt', 'Score':0, 'Of':0},
            {'Attempt':'5th Attempt', 'Score':0, 'Of':0}
        ]
        
        for test in tests:
            if not test.alias in attempts:
                attempts[test.alias] = 0
            else:
                attempts[test.alias] += 1
            
            outof = DBSession.query(TestsResults).filter(TestsResults.tests_id==test.id).count()
            percent = test.total_percentage / outof
            
            if attempts[test.alias] < 5:
                data[attempts[test.alias]]['Score'] += percent
                data[attempts[test.alias]]['Of'] += 1
                
        for i in range(5):
            if data[i]['Of'] > 0:
                data[i]['Score'] = float(data[i]['Score'] / data[i]['Of'])
                data[i]['Attempt'] += ' : ' + str(data[i]['Of']) + ' users '
        
        self.response['dataset'] = data
        return self.response
        

        
        
開發者ID:hietpasd,項目名稱:quizsmith,代碼行數:41,代碼來源:edit_report_avg_score.py

示例5: edit_delete

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def edit_delete(self):
     id = self.request.matchdict['id']
     classname = str(self.request.matchdict['type'])
     back = self.request.params.get('back',None)
     if back == None or not back.startswith(self.request.application_url):
         return HTTPFound(location=self.request.application_url) 
     
     type = Import('quizsmith.app.models',str(classname))
     obj = DBSession.query(type).filter(type.id==id).first()
     if obj:
         DBSession.delete(obj)
         DBSession.flush()
     
     transaction.commit() # make it so number one
     return HTTPFound(location=self.request.params['back'])
開發者ID:hietpasd,項目名稱:quizsmith,代碼行數:17,代碼來源:edit_delete.py

示例6: get_all_ranking

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def get_all_ranking(cls,test):
     sq = DBSession.query(Tests).filter(Tests.completed==1).filter(Tests.created>=LeaderBoard.archive_date()).order_by('total_competitive desc').subquery()
     results = DBSession.query(Tests).select_from(sq).filter(Tests.total_competitive > test.total_competitive).group_by('alias').all()
     data = Result2Dict(test)
     data['ranking'] = len(results) + 1  #prevent zero rank
     return data  
開發者ID:polklibrary,項目名稱:quizsmith,代碼行數:8,代碼來源:leaderboard.py

示例7: all_counts

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def all_counts(cls,by='id',sort='asc',limit=1000,offset=0):
     return DBSession.query(Tests).filter(Tests.completed==1).filter(Tests.created>=LeaderBoard.archive_date()).group_by('alias').count()
開發者ID:polklibrary,項目名稱:quizsmith,代碼行數:4,代碼來源:leaderboard.py

示例8: all_categories

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def all_categories(cls,by='id',sort='asc',limit=1000,offset=0):
     sq = DBSession.query(Tests).filter(Tests.completed==1).filter(Tests.created>=LeaderBoard.archive_date()).order_by('total_competitive desc').subquery()
     sq2 = DBSession.query(Tests).select_from(sq).group_by('alias').subquery()
     return DBSession.query(Tests).select_from(sq2).order_by(by + ' ' + sort).limit(limit).offset(offset).all()
開發者ID:polklibrary,項目名稱:quizsmith,代碼行數:6,代碼來源:leaderboard.py

示例9: categories

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def categories(cls):
     return DBSession.query(Tests).group_by('category').order_by('category asc')
開發者ID:polklibrary,項目名稱:quizsmith,代碼行數:4,代碼來源:leaderboard.py

示例10: counts

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def counts(cls,category):
     return DBSession.query(Tests).filter(Tests.category==category).filter(Tests.completed==1).filter(Tests.created>=LeaderBoard.archive_date()).group_by('alias').count()
開發者ID:polklibrary,項目名稱:quizsmith,代碼行數:4,代碼來源:leaderboard.py

示例11: factory

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def factory(cls):
     aclist = [(Allow,Everyone,cls.ANONYMOUS),(Allow,Authenticated,cls.AUTHENTICATED),]   
     for group in DBSession.query(Groups).all():
         aclist.append((Allow, group.name, group.permissions()))
     return aclist
開發者ID:polklibrary,項目名稱:quizsmith,代碼行數:7,代碼來源:security.py

示例12: groupfinder

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
def groupfinder(userid, request):
    if Users.by(userid).first():
        results = DBSession.query(Users,Groups).filter(Users.id == userid).join(Users.groups).all()
        return [result.Groups.name for result in results]
    return []
開發者ID:polklibrary,項目名稱:quizsmith,代碼行數:7,代碼來源:security.py

示例13: get_transition_out

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def get_transition_out(self):
     from quizsmith.app.models import Transitions
     return DBSession.query(Transitions).join(Categories.transitions_out).filter(Categories.id==self.id).first()
開發者ID:hietpasd,項目名稱:quizsmith,代碼行數:5,代碼來源:categories.py

示例14: all_properties

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
 def all_properties(cls):
     results = DBSession.query(Properties).all()
     properties = {}
     for result in results:
         properties[result.prop_name] = result.prop_value
     return properties
開發者ID:hietpasd,項目名稱:quizsmith,代碼行數:8,代碼來源:properties.py

示例15: run

# 需要導入模塊: from quizsmith.app.models import DBSession [as 別名]
# 或者: from quizsmith.app.models.DBSession import query [as 別名]
    def run(self):
        category = self.request.params.get('category','missing')
        
        attempts = {} # { 'KEY_USER_NAME' : INT_ATTEMPT_COUNT }
        questions = []
        
        tests = DBSession.query(Tests).filter(Tests.category==category).filter(Tests.created>=self.start).filter(Tests.created<=self.end).order_by('created asc')
        if not self.include_incompleted:
            tests = tests.filter(Tests.completed==1)
        tests = tests.all()
        
        for test in tests:
            if not test.alias in attempts:
                attempts[test.alias] = 1
            else:
                attempts[test.alias] += 1
            
            results = DBSession.query(TestsResults).filter(TestsResults.tests_id==test.id).all()
            for result in results:
                
                data = None
                for ds in questions:
                    if ds.equals(result.question):
                        data = ds
                if data == None:
                    data = self.Struct(result.question, result.question_sets_id)
                    data.wrong_multiplier = test.max_wrong_answer_allowed
                    questions.append(data)
                
                if attempts[test.alias] == 1:
                    if result.wrong_attempts != 0:
                        if result.wrong_attempts == test.max_wrong_answer_allowed:
                            data.attempts_one_wrong += 1
                        else:
                            data.attempts_one_partial += 1
                        data.wrongly_answered(result.answer_choices, data.answer_one_choices)
                    else:
                        data.attempts_one_correct += 1
                    
                if attempts[test.alias] == 2:
                    if result.wrong_attempts != 0:
                        if result.wrong_attempts == test.max_wrong_answer_allowed:
                            data.attempts_two_wrong += 1
                        else:
                            data.attempts_two_partial += 1
                        data.wrongly_answered(result.answer_choices, data.answer_two_choices)
                    else:
                        data.attempts_two_correct += 1
                        
                if attempts[test.alias] == 3:
                    if result.wrong_attempts != 0:
                        if result.wrong_attempts == test.max_wrong_answer_allowed:
                            data.attempts_three_wrong += 1
                        else:
                            data.attempts_three_partial += 1
                        data.wrongly_answered(result.answer_choices, data.answer_three_choices)
                    else:
                        data.attempts_three_correct += 1
                    
        for question in questions:
            data = {}
            data['question'] = question.question
            data['question_sets_id'] = str(question.question_sets_id)
            data['wrong_multiplier'] = question.wrong_multiplier
            
            data['one_percent'] = self.percentage(float(question.attempts_one_wrong) / float(question.attempts_one_wrong + question.attempts_one_correct))
            data['one_wrong'] = question.attempts_one_wrong
            data['one_partial'] = question.attempts_one_partial
            data['one_correct'] = question.attempts_one_correct
            data['one_answers'] = filter(lambda x: x['wrong'] != 0, sorted(question.answer_one_choices, key=itemgetter('wrong'), reverse=True))

            data['two_percent'] = self.percentage(float(question.attempts_two_wrong) / float(question.attempts_two_wrong + question.attempts_two_correct))
            data['two_wrong'] = question.attempts_two_wrong
            data['two_partial'] = question.attempts_two_partial
            data['two_correct'] = question.attempts_two_correct
            data['two_answers'] = filter(lambda x: x['wrong'] != 0, sorted(question.answer_two_choices, key=itemgetter('wrong'), reverse=True))

            data['three_percent'] = self.percentage(float(question.attempts_three_wrong) / float(question.attempts_three_wrong + question.attempts_three_correct))
            data['three_wrong'] = question.attempts_three_wrong
            data['three_partial'] = question.attempts_three_partial
            data['three_correct'] = question.attempts_three_correct
            data['three_answers'] = filter(lambda x: x['wrong'] != 0, sorted(question.answer_three_choices, key=itemgetter('wrong'), reverse=True))
            
            self.response['rows'].append(data)
        return self.response
開發者ID:hietpasd,項目名稱:quizsmith,代碼行數:87,代碼來源:problematic_questions.py


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