|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
下面的代码是小甲鱼的答案,代码第七行的for 循环是个迭代过程,那么这里的eachline代表的是什么?迭代文本中的每个字符?还是每行?感觉都解释不通,但我想不出别的了,求教一下大家是什么意思。
def file_replace(file_name, rep_word, new_word):
f_read = open(file_name)
content = []
count = 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)
本帖最后由 heidern0612 于 2018-12-24 16:38 编辑
- for eachline in f_read:
- if rep_word in eachline: # 判断需要改的字符串或单词是否在这一行中
- count1 = eachline.count(rep_word) # 每行中需要改的字符串的个数
- eachline = eachline.replace(rep_word,new_word) # 改字符串
- count += count1 # 自加每行的个数
- # 加到列表中去
- content.append(eachline)
复制代码
|
|