【每周一坑】单词本 +【解答】三国演义中谁的存在感最强

简介: 今天本系列打算做个小小的尝试,不再是一个单独的题目,而是一个连环坑!我希望通过之后的三四期,逐步引导大家做出一个功能较完整的小工具。不过我现在没有底,不知道到最后能有多少人把坑给填完。愿意接受挑战的,现在就开始了!

“每周一坑”这个系列在本教室的文章中,阅读量不算高。但我屡次在和读者沟通时听到说“我都有跟着每周一坑里的题在做”。这是个有意思的普遍现象:内容的价值和传播度并不成正比。


因此如果你每天的阅读主要依赖于别人的转发和“智能”的推送,或许该考虑是不是增加点更有价值的“主动阅读”了。


PS:上周的送书活动的中奖名单:捷、七步、司夜、教我点英语吧、HalShaw、剃刀奥卡姆、兜里有糖、李明毅、贝玉尚、A暴躁的眼镜吴。奖品书籍将在下周一寄出。类似活动我们经常会有,大家别客气啊(比如这次只要你留言的项目或文章超过3个赞就能拿到书的


今天本系列打算做个小小的尝试,不再是一个单独的题目,而是一个连环坑!我希望通过之后的三四期,逐步引导大家做出一个功能较完整的小工具。不过我现在没有底,不知道到最后能有多少人把坑给填完。愿意接受挑战的,现在就开始了!


我们的目标是:


单词本


这应该是一个很多人都可以用到的小工具。在平常学习或阅读的时候,遇到一些生词,随手加入生词本里,有空的时候可以拿出来复习。很多背单词工具都有这样的功能。不过你有没有想过自己实现一个这样工具呢?既是一个练手的好题材,也能定制化一些自己想要的功能。


初步的设想,这个单词本工具可以随时添加生词,自动配上释义,支持导入导出单词本,可以进行复习、测试,并记录每个词的熟悉度。(有其他功能建议,欢迎在文后留言)


这个程序可以写得很简单,帮你巩固 Python 的基础语法、数据结构使用、文件读写。而你也可以根据自己的能力更进一步,给它增加 GUI、网络、数据处理等功能。


作为第一期,我们的起步要求很简单:


  1. 可在命令行输入单词或词组
  2. 保存在文件中并记录添加的日期
  3. 提示保存成功或单词已存在
  4. 提示现有单词总数
  5. 程序可重复运行(保证读写功能正常)


效果演示:



详细解答和参考代码将在下次栏目中给出,也可以其他同学在留言中的代码。

期待各位同学提交解答,更期待你能完成整个系列。

提交代码可以使用 paste.ubuntu.com

codeshare.io 等代码分享网站,只需将代码复制上去保存,即可获得一个分享地址,非常方便。



【解答】三国演义中谁的存在感最强


上次的题目《三国演义中谁的存在感最强》,关键是用好两个库就可以了:


jiebacollections.Counter


这里给一份参考解答:


# 读取三国原文
with open('sanguo.txt', encoding='utf8', errors='ignore') as f:
    text = f.read()
# 分词
import jieba
words = jieba.lcut(text)
words_valid = []
# 排除词
excludes = ['将军', '却说', '二人', '不可', '荆州', '不能', '如此', '商议', '如何', '主公', '军士', '左右', '军马', '引兵', '次日', '大喜', '天下', '东吴', '于是', '今日', '不敢', '魏兵', '陛下', '人马', '都督', '一人', '不知', '汉中', '众将', '只见', '后主', '蜀兵']
for word in words:
    if len(word) < 2:
        continue
    if word in excludes:
        continue
    # 合并词
    if word.endswith('曰'):
        word = word[:-1]
    if "诸葛亮" in word or '孔明' in word:
        word = '孔明'
    elif "关公" in word or "云长" in word:
        word = "关羽"
    elif "玄德" in word or '皇叔' in word:
        word = "刘备"
    elif "孟德" in word or "曹丞相" in word :
        word = '曹操'
    words_valid.append(word)
# 统计高频词
from collections import Counter
ct = Counter(words_valid)
ct.most_common(10)


除了分词和统计的调用外,中间还做了两件事:


  1. 把一些高频但我们不关注的词去掉(这里其实是先运行过一次代码,找出的这些高频词)
  2. 把一些同目标的词合并,比如“诸葛亮”和“孔明”。另外这里用 in 而不是 ==,是因为可以把“孔明曰”、“孔明笑”之类的词也统计进来。


执行结果:



看来,刘皇叔还是当之无愧的C位,不过诸葛丞相的地位也不可小觑。


上次各位的回应让我有些尴尬,只有一位同学提交了答案。不过,这位同学的答案却是相当惊艳,以至于我决定原封不动地搬运过来,放在今天的下一条。强烈推荐大家去看一下 @王文亚 同学的解答,不仅统计了书中人名的出现频率,还进一步分析并绘制了不同人物在不同章回出现的分布、人物之间的关系等。尽管其中有些小细节值得商榷,但整体上已经相当不错。



除了这个题目,之前几次的题目王同学也有很不错的解答,值得各位借鉴学习。项目地址 https://github.com/Damon0626/Crossin-Programming-Room


其他同学也动起手来呀!

期待在下一期中看到你们的代码。


其他内容回复左侧关键词获取:

python :零基础入门课程目录

新手 :初学者指南及常见问题

资源 :超过500M学习资料网盘地址

项目 :十多个进阶项目代码实例

如需了解视频课程及答疑群等更多服务,请号内回复 码上行动

代码相关问题可以在论坛上发帖提问 bbs.crossincode.com

推荐阅读:

爬抖音 | AI名画 | 押韵工具 | 虎扑 | 如何debug | 查天气 | 我用Python | 知乎 | 排序 | 电影票 | 技术宅 | 单词表 | 新手建议 | 如何提问 | 中文编

相关文章
通关《完蛋!我被LLM包围了! 》1~8关
欢迎来的“完蛋!我被LLM包围了”小游戏,《完蛋!我被LLM包围了!》是一款智力挑战游戏。该项目利用LLM, 基于ModelScope社区内现有的LLM对话Gradio应用程序代码,结合知乎文章《如何用“不可能”完成任务》中的预设问题,自动生成了对应的游戏代码,创造了一个独特的游戏体验。 在这个游戏中,玩家需要巧妙构造问题,挑战LLM给出满足特定条件的回答。(卡在第九关了一直过不去QAQ)
|
4月前
|
流计算
IELTS学习(004) - 单词(太空探索篇)
IELTS学习(004) - 单词(太空探索篇)
23 0
|
5月前
英文捡贝壳
记录生活中的英语,“不积跬步无以至千里”
|
7月前
|
存储
汪子熙趣味成语接龙的游戏软件设计架构说明
汪子熙趣味成语接龙的游戏软件设计架构说明
68 0
|
9月前
|
数据采集 存储 人工智能
【每周一坑】自动翻译 | 【解答】单词本
提示:翻译功能可以通过网上的翻译 API 实现,你所要了解的就是如何发起网络请求,以及如果对返回结果进行处理。这也算是基本的爬虫操作。
|
11月前
|
算法
KMP算法——我欲修仙(功法篇)
KMP算法——我欲修仙(功法篇)
87 0
|
存储 算法 Java
字符作画,我用字符画个冰墩墩
字符作画,我用字符画个冰墩墩
191 0
字符作画,我用字符画个冰墩墩