Python小实验,疯狂填词

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python小实验,疯狂填词相关的知识,希望对你有一定的参考价值。

#! python
# coding: utf-8
##创建一个疯狂填词(Mad Libs)程序,它将读入文本文件,并让用户在该文本文件中出现ADJECTIVE、NOUN、ADVERB 或VERB 等单词的地方,加上他们自
#己的文本。例如,一个文本文件可能看起来像这样:
# The ADJECTIVE panda walked to the NOUN and then VERB. A nearby NOUN wasunaffected by these events.
#程序将找到这些出现的单词,并提示用户取代它们。
#Enter an adjective:
#silly
#Enter a noun:
#chandelier
#Enter a verb:
#screamed
#Enter a noun:
#pickup truck
#以下的文本文件将被创建:
#The silly panda walked to the chandelier and then screamed. A nearby pickup truck was unaffected by these events.
#结果应该打印到屏幕上,并保存为一个新的文本文件。


# 程序代码如下:
import re
f1 = open(‘a.txt‘,‘r‘)
strf1 = f1.read()
print("原文件内容为:")
print(strf1)
#将字符串以空格为分隔符生成一个列表
strf1_list = strf1.split()
#去除列表中元素结尾的逗号和句号,并获取有逗号和句号的元素索引和值保存在一个字典中
i = 0
j = {}
for strs in strf1_list:
    if ‘.‘ in strs or ‘,‘ in strs:
        j[i]=strs
        strf1_list[i] = strs[:-1]
    i += 1
print("打印出没有句号和逗号的列表")
print(strf1_list)
print("打印出有句号有逗号的元素索引和值")
print(j)
f1.close()
# 由于原文件需要被替换的单词都是大写的英文单词
#  使用正则表达式找出原文件中所有将被替换的单词
replist = re.findall(r‘[A-Z]{2,}‘,strf1)
print("原文件中将被替换的单词为:")
print(replist)
for rep in replist:
    #元音字母开头的字母提示信息不一样
    if rep[0] in ‘AEIOU‘:
        inputstr = input("Enter an %s " % rep)
    else:
        inputstr = input("Enter a %s " % rep)
    print(inputstr)
    # 先将替换后的单词插入到原列表对应的位置
    strf1_list.insert(strf1_list.index(rep),inputstr)
    # 再将原先的单词删除
    strf1_list.remove(rep)
#将上面去除逗号或句号的元素后面将逗号或句号添加回去,根据j字典可以准确找到结尾有逗号或句号的元素
for key,value in j.items():
   strf1_list[key] = str(strf1_list[key]) + str(value[-1])
# 将列表转换为字符串
newstr = ‘ ‘.join(strf1_list)
print("替换后的内容为:") #
print(newstr)
# 将新的字符串写入文件b.txt中,并打印到屏幕
f2 = open(‘b.txt‘,‘w+‘)
f2.write(newstr)
f2.close()


本文出自 “流星宇” 博客,请务必保留此出处http://8789878.blog.51cto.com/8779878/1931576

以上是关于Python小实验,疯狂填词的主要内容,如果未能解决你的问题,请参考以下文章

Python小实验2—产生式系统实验

30个Python物联网小实验5:光线感应灯

Python小实验——密码强度

Qt事件机制的小实验

数据采集三道小实验 | 文末送书✨

CISCO综合小实验