|
|

楼主 |
发表于 2019-11-19 02:43:35
|
显示全部楼层
谢谢各位大佬的回复,我去看了一下小甲鱼老师的答案,但是小甲鱼老师的答案也存在一个bug,虽然他可以解决数据不重复的问题,但是他在计算有多少个文件中有多少个想要代替的字数时是错的。
所以我修改了一下他的代码,情况都解决了
- def file_replace(file_name, rep_word, new_word):
- f_read = open(file_name)
- content = []
- count = f_read.read().count(rep_word)
- f_read.seek(0,0)
-
- for eachline in f_read:
- if rep_word in eachline:
- #count = eachline.count(rep_word) #count感觉应该用这个
- eachline = eachline.replace(rep_word, new_word)
- content.append(eachline)
- decide = input('\n文件 %s 中共有%s个【%s】\n您确定要把所有的【%s】替换为【%s】吗?\n【YES/NO】:' \
- % (file_name, count, rep_word, rep_word, new_word))
- if decide in ['YES', 'Yes', 'yes']:
- f_write = open(file_name, 'w')
- f_write.writelines(content)
- f_write.close()
- f_read.close()
- file_name = input('请输入文件名:')
- rep_word = input('请输入需要替换的单词或字符:')
- new_word = input('请输入新的单词或字符:')
- file_replace(file_name, rep_word, new_word)
复制代码 |
|