本文整理汇总了Python中oasis.lib.Exams.touchUserExam方法的典型用法代码示例。如果您正苦于以下问题:Python Exams.touchUserExam方法的具体用法?Python Exams.touchUserExam怎么用?Python Exams.touchUserExam使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类oasis.lib.Exams
的用法示例。
在下文中一共展示了Exams.touchUserExam方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: mark_exam
# 需要导入模块: from oasis.lib import Exams [as 别名]
# 或者: from oasis.lib.Exams import touchUserExam [as 别名]
def mark_exam(user_id, exam_id):
""" Submit the assessment and mark it.
Returns True if it went well, or False if a problem.
"""
numQuestions = Exams.get_num_questions(exam_id)
status = Exams.get_user_status(user_id, exam_id)
log(INFO,
"Marking assessment %s for %s, status is %s" %
(exam_id, user_id, status))
examtotal = 0.0
for position in range(1, numQuestions + 1):
q_id = General.get_exam_q(exam_id, position, user_id)
answers = DB.get_q_guesses(q_id)
# There's a small chance they got here without ever seeing a question,
# make sure it exists.
DB.add_exam_q(user_id, exam_id, q_id, position)
# First, mark the question
try:
marks = General.mark_q(q_id, answers)
DB.set_q_status(q_id, 3) # 3 = marked
DB.set_q_marktime(q_id)
except OaMarkerError:
log(WARN,
"Marker Error in question %s, exam %s, student %s!" %
(q_id, exam_id, user_id))
return False
parts = [int(var[1:])
for var in marks.keys()
if re.search("^A([0-9]+)$", var) > 0]
parts.sort()
# Then calculate the mark
total = 0.0
for part in parts:
try:
mark = float(marks['M%d' % (part,)])
except (KeyError, ValueError):
mark = 0
total += mark
DB.update_q_score(q_id, total)
examtotal += total
Exams.set_user_status(user_id, exam_id, 5)
Exams.set_submit_time(user_id, exam_id)
Exams.save_score(exam_id, user_id, examtotal)
Exams.touchUserExam(exam_id, user_id)
log(INFO,
"user %s scored %s total on exam %s" %
(user_id, examtotal, exam_id))
return True