《Python编程快速上手—让繁琐工作自动化》第8章实践项目答案

8.5 项目:生成随机的测验试卷文件

项目要求:假如你是一位地理老师,班上有 35 名学生,你希望进行美国各州首府的一个小测验。不妙的是,班里有几个坏蛋,你无法确信学生不会作弊。你希望随机调整问题的次序,这样每份试卷都是独一无二的,这让任何人都不能从其他人那里抄袭答案。

import os

os.chdir(os.path.join(os.getcwd(),'new'))

import random

# import quiz data
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'}

# Generate 35 quiz files.
for quizNum in range(1,36):
    # TODO: Create the quiz and answer key files.
    quizfile = open('quizfile%02d.txt' % (quizNum),'w')
    quizans = open('quiznum%02d.txt' % (quizNum),'w')

    # TODO: Write out the header for the quiz.
    quizfile.write('Name:\n\nDate:\n\n')
    quizfile.write(('State Capital Quiz form-%02d' % (quizNum)).rjust(50))
    quizfile.write('\n\n')
    quizans.write('Answers for quiz form-%02d:\n' % (quizNum))

    # TODO: Shuffle the order of the states.
    state_list = list(capitals.keys())
    random.shuffle(state_list)

    # TODO: Loop through all 50 states, making a question for each.
    for questionNum in range(len(capitals)):
        quizfile.write("%d. What's the capital of %s?\n" % (questionNum+1, 
            state_list[questionNum]))
# Write the question and the answer options to the quiz file.
        ans_sheet = []
        wrong_ans = list(capitals.values())
        wrong_ans.remove(capitals[state_list[questionNum]])
        ans_sheet = random.sample(wrong_ans, 3)
        ans_sheet.append(capitals[state_list[questionNum]])
        random.shuffle(ans_sheet)
        for i in range(4):
            quizfile.write("    %s. %s\n" % ('ABCD'[i], ans_sheet[i]))
        quizfile.write('\n')
# Write the answer key to a file.
        quizans.write('%d. %s(%s)\n' % (questionNum+1, 
            'ABCD'[ans_sheet.index(capitals[state_list[questionNum]])], 
            capitals[state_list[questionNum]]))

    quizfile.close()
    quizans.close()

跟着这个项目解答练手需要耐心,因为代码有点长,更加需要突破自己的惰性和心理障碍去一步步执行。作者这个项目讲解很细致。


8.6 项目:多重剪贴板

项目要求:程序将利用一个关键字保存每段剪贴板文本。例如,当运行 py mcb.pyw save spam,剪贴板中当前的内容就用关键字 spam 保存。通过运行 py mcb.pyw spam,这段文本稍后将重新加载到剪贴板中。如果用户忘记了都有哪些关键字,他们可以运行 py mcb.pyw list,将所有关键字的列表复制到剪贴板中。

#! python3

import shelve, pyperclip, sys

mcbshelf = shelve.open('mcb')

mcbshelf['name'] = 'wuwuwuwuwu'
mcbshelf['address'] = 'xiangshanli co. Tl'

if len(sys.argv) == 3 and sys.argv[1].lower == 'save':
    mcbshelf[sys.argv[2]] = pyperclip.paste()
elif len(sys.argv) == 2:
    if sys.argv[1].lower() == 'list':
        pyperclip.copy(str(list(mcbshelf.keys())))
    elif sys.argv[1] in mcbshelf:
        pyperclip.copy(mcbshelf[sys.argv[1]])

print(mcbshelf['name'])
mcbshelf.close()

思路:这里需要理解命令行参数,通过cmd执行语句

8.9.1 实践项目:扩展多重剪贴板

项目要求:扩展本章中的多重剪贴板程序,增加一个 delete <keyword>命令行参数,它将从 shelf 中删除一个关键字。然后添加一个 delete 命令行参数,它将删除所有关键字。

#! python3

import shelve, pyperclip, sys

mcbshelf = shelve.open('mcb')

if len(sys.argv) == 3 and sys.argv[1].lower() == 'save':
    mcbshelf[sys.argv[2]] = pyperclip.paste()
elif len(sys.argv) == 3 and sys.argv[1].lower() == 'delete':
    try:
        del mcbshelf[sys.argv[2]]
    except KeyError:
        print('there is no key you just entered, please check <pytest.pyw list>')
elif len(sys.argv) == 2:
    if sys.argv[1].lower() == 'list':
        pyperclip.copy(str(list(mcbshelf.keys())))
    elif sys.argv[1] in mcbshelf:
        pyperclip.copy(mcbshelf[sys.argv[1]])
    elif sys.argv[1].lower() == 'delete':
        mcbshelf.clear()
        print('all data have been delete!')
mcbshelf.close()

思路:

  1. 理解了项目8.6后,加个delete语句就不难了
  2. 注意加个try-except进行测试

8.9.2 实践项目:疯狂填词

Paste_Image.png
#! python3
# this is program named 'Mad Libs'
"""
    # this is the original txt
    The ADJECTIVE panda walked to the NOUN and then VERB. A nearby NOUN was
    unaffected by these events.

    # input() GUI
    Enter an adjective:
    silly
    Enter a noun:
    chandelier
    Enter a verb:
    screamed
    Enter a noun:
    pickup truck

    # output a new txt like this
    The silly panda walked to the chandelier and then screamed. A nearby pickup
    truck was unaffected by these events.
"""

# read the original txt
filename = 'o_madlibs.txt'
with open(filename,'r') as o_ml:
    o_text = o_ml.readline()

# give an input()
ADJ = input('Enter an adjective:\n')
NOU1 = input('Enter a noun:\n')
VER = input('Enter a verb\n')
NOU2 = input('Enter a noun:\n')

# write out a new txt , whose words haved been replaced
o_text = o_text.replace('ADJECTIVE',ADJ)
o_text = o_text.replace('NOUN',NOU1,1)
o_text = o_text.replace('VERB', VER)
o_text = o_text.replace('NOUN',NOU2,1)

print(o_text)
with open('new_libs.txt','w') as f:
    f.write(o_text)

思路:

  1. 想了下,根本就没必要用正则啊!
  2. 所以就投机取巧用replace代替了哈哈哈,这才符合python之禅

8.9.3 正则表达式查找

项目要求:编写一个程序,打开文件夹中所有的.txt 文件,查找匹配用户提供的正则表达式的所有行。结果应该打印到屏幕上。

#! python3
# this is program named 'Regex Search TXT'

"""
编写一个程序,打开文件夹中所有的.txt 文件,查找匹配用户提供的正则表达
式的所有行。结果应该打印到屏幕上
"""

import re, os

# 编写一个正则表达式,匹配txt中所有小写5个字母的单词
five_word = re.compile(r'\s[a-z]{5}\s')

# 打开指定文件夹的所有txt文件,匹配所有行
re_ans = []

pathname = r'c:\users\hp\desktop'
for filename in os.listdir(pathname):
    if filename.endswith('.txt'):
        with open(filename, 'r') as f:
            t_text = f.read()
            t_re_find = five_word.findall(t_text)
            re_ans += t_re_find

print(re_ans)

思路:

  1. 用了个简单的正则(找5个小写字母的单词)
  2. 配合os.listdir,找出txt文件,并for循环一一打开并匹配正则

环境:python3

想做这个系列文章,就是因为当时看这本书时,想看看网上有没更优美的解决,但是略难找到。所以就把自己的项目练习放在了一个txt文件中,现在把练习代码放到这里,有不足之处希望大家能给出指导意见及相互交流、提升。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容