• 创建 35 份不同的测验试卷。
• 为每份试卷创建 50 个多重选择题,次序随机。
• 为每个问题提供一个正确答案和 3 个随机的错误答案,次序随机。
• 将测验试卷写到 35 个文本文件中。
• 将答案写到 35 个文本文件中。
#! python3
# randomQuizGenerator.py - Creates quizzes with questions and answers in
# random order, along with the answer key.
# The quiz data. Keys are states and values are their capitals.
import random
capitals = {'Alabama': 'Montgomery', 'Alaska': 'Juneau', 'Arizona': 'Phoenix',
'Arkansas': 'Little Rock', 'California': 'Sacramento', 'Colorado':
'Denver','Connecticut': 'Hartford', 'Delaware': 'Dover', 'Florida':
'Tallahassee','Georgia': 'Atlanta', 'Hawaii': 'Honolulu', 'Idaho':
'Boise', 'Illinois': 'Springfield', 'Indiana': 'Indianapolis', 'Iowa':
'Des Moines', 'Kansas': 'Topeka', 'Kentucky': 'Frankfort', 'Louisiana':
'Baton Rouge', 'Maine': 'Augusta', 'Maryland': 'Annapolis', 'Massachusetts':
'Boston', 'Michigan': 'Lansing', 'Minnesota': 'Saint Paul', 'Mississippi':
'Jackson', 'Missouri': 'Jefferson City', 'Montana': 'Helena', 'Nebraska':
'Lincoln', 'Nevada': 'Carson City', 'New Hampshire': 'Concord',
'New Jersey': 'Trenton', 'New Mexico':'Santa Fe', 'New York': 'Albany', 'North Carolina': 'Raleigh',
'North Dakota': 'Bismarck', 'Ohio': 'Columbus', 'Oklahoma': 'Oklahoma City',
'Oregon': 'Salem', 'Pennsylvania': 'Harrisburg', 'Rhode Island': 'Providence',
'South Carolina': 'Columbia', 'South Dakota': 'Pierre', 'Tennessee':
'Nashville', 'Texas': 'Austin', 'Utah': 'Salt Lake City', 'Vermont':
'Montpelier', 'Virginia': 'Richmond', 'Washington': 'Olympia', 'West Virginia':
'Charleston', 'Wisconsin': 'Madison', 'Wyoming': 'Cheyenne'}
for quizNum in range(35):
# 创建试卷和答案文件
quizFile = open('capticalsquiz%s.txt' % (quizNum + 1), 'w')#%s 的意思是,这个%s是把后面%()里的字符串填入
answerKeyFile = open('capticalsquiz_answers%s.txt' % (quizNum + 1), 'w')
# 写标题和开头
quizFile.write('Name:\n\nDate:\n\nClass:\n\n')
quizFile.write(' ' * 20 + 'State Capticals Quiz (From %s)' % (quizNum + 1))
quizFile.write('\n\n')
# 打乱capital字典
states = list(capitals.keys())
random.shuffle(states) # 打乱states的顺序
# 循环states,制造50个问题
for questionNum in range(50):
correctAnswer = capitals[states[questionNum]]
wrongAnswers = list(capitals.values())
del wrongAnswers[wrongAnswers.index(correctAnswer)] # 删除列表中的正确答案
# random.sample()函数使得这种选择很容易,它的第一个参数是你希望选择的列表,第二个参数是你希望选择的值的个数。
wrongAnswers = random.sample(wrongAnswers, 3)
answerOption = wrongAnswers + [correctAnswer]
random.shuffle(answerOption)
# 在文件中写入问题
quizFile.write('%s. What is the capital of %s?\n' % (questionNum + 1,
states[questionNum]))
for i in range(4):
quizFile.write(' %s. %s\n' % ('ABCD'[i], answerOption[i]))
quizFile.write('\n')
# 在答案卷中写入答案
answerKeyFile.write('%s. %s\n' % (questionNum + 1, 'ABCD'[
answerOption.index(correctAnswer)]))
quizFile.close()
answerKeyFile.close()
Python 列表 index() 方法用于从列表中找出某个对象第一个匹配项的索引位置,如果这个对象不在列表中会报一个异常。
index() 方法语法:
L.index(obj[,start=0[,stop=len(L)]])
参数:
obj – 查找的对象。
start – 可选参数,开始索引,默认为0。(可单独指定)
stop – 可选参数,结束索引,默认为列表的长度。(不能单独指定)
返回值:
如果包含检索的对象返回开始的索引值,否则抛出异常。
例:
L = ['Google', 'Runoob', 'Taobao']
print(L.index('Taobao'))
print(L.index('Google',1))
输出:
2
Traceback (most recent call last):
File "test.py", Lne 22, in <module>
print(tu.index('Google',1))
ValueError: tuple.index(x): x not in tuple