前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【每周一坑】单词本 +【解答】三国演义中谁的存在感最强

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

作者头像
Crossin先生
修改2018-12-25 12:02:37
3510
修改2018-12-25 12:02:37
举报

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

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

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


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

我们的目标是:

单词本

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

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

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

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

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

效果演示:

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

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

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

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

往期问题可通过公众号菜单栏“课外辅导”栏目中进入查看。


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

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

jiebacollections.Counter

这里给一份参考解答:

代码语言:javascript
复制
# 读取三国原文
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

其他同学也动起手来呀!

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

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-12-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Crossin的编程教室 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档