马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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)
请问这个答案代码中,把要替换的每一行存在列表中,但是后面的写入过程是怎么确定是哪一行的呢?
content列表中的修改过的每一行字符串应该只对应下标0123才对啊,但是写入过程中似乎没有去规定写入到特定的一行。
第8~12行的for循环,逐行读取文件到eachline
第9~11行,检查eachline中是否有要替换的字符,若有的话就替换掉。
第12行,将eachline写入content中。
循环结束后,content中就是源文件的所有内容了(需要替换的已经替换掉了),每一行和原来的顺序是一样的。
第17~20行是将替换后的内容写回到源文件。
这是整体谢汝的,并不是说哪一行有对应的字符串就写哪一行。
|