鱼C论坛

 找回密码
 立即注册
查看: 4041|回复: 8

[已解决]第29讲最后一个 全部替换问题

[复制链接]
发表于 2016-9-23 22:14:39 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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)      
            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)




count = eachline.count(rep_word)  为什么  这里是 =  不是  +=  
还有    for eachline in f_read:                        
这个是逐行 读取??

    if decide in ['YES', 'Yes', 'yes']:            
        f_write = open(file_name, 'w')           
        f_write.writelines(content)            
        f_write.close()                        
还有这段代码 为什么是 能把原来位置的 代码 替换成新的代码??
最佳答案
2017-11-29 00:22:17
1. 我个人觉得应该是count += eachline.count(rep_word)  ,否则无法叠加。
   可参考这个帖子:http://bbs.fishc.com/forum.php?m ... B%B2%BF%CC%E6%BB%BB

2.for eachline in f_read:   这道题我也问过,感觉文件搭配for语句默认是按行来读取的,自己做做实验就知道了。至于为什么,等以后我能读懂python的语句如何实现,应该就能理解了。目前我只是默默记下来了。

3. if decide in ['YES', 'Yes', 'yes']:            
        f_write = open(file_name, 'w')           
        f_write.writelines(content)            
        f_write.close()   
这是因为前面新建了一个content[]的空列表,在读取f_read的每行数据时,其实就已经把需要替换的内容全部放到content里面了。一旦决定替换,就可以将content的内容以覆盖源文件的方式写入。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2016-9-23 22:15:41 | 显示全部楼层
学到 三十出头 零基础的真的感觉有点困难了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-11-29 00:22:17 | 显示全部楼层    本楼为最佳答案   
1. 我个人觉得应该是count += eachline.count(rep_word)  ,否则无法叠加。
   可参考这个帖子:http://bbs.fishc.com/forum.php?m ... B%B2%BF%CC%E6%BB%BB

2.for eachline in f_read:   这道题我也问过,感觉文件搭配for语句默认是按行来读取的,自己做做实验就知道了。至于为什么,等以后我能读懂python的语句如何实现,应该就能理解了。目前我只是默默记下来了。

3. if decide in ['YES', 'Yes', 'yes']:            
        f_write = open(file_name, 'w')           
        f_write.writelines(content)            
        f_write.close()   
这是因为前面新建了一个content[]的空列表,在读取f_read的每行数据时,其实就已经把需要替换的内容全部放到content里面了。一旦决定替换,就可以将content的内容以覆盖源文件的方式写入。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-11-29 10:35:50 | 显示全部楼层
首先我觉得二楼的鱼油回答的已经很好了,我这里补充两点
1、通过实际操作count = eachline.count(rep_word)  就应该替换成count += eachline.count(rep_word)
2、 for eachline in f_read:是逐行读取的,你可以理解为每一行是被当被列表里的一个元素,思路可以参考课后作业第0题
3、同2楼说的一样,comtent中存放的是替换之后的文本,这样比逐行换效率要高

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-7-11 20:50:56 | 显示全部楼层
感谢解答!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-10 23:30:37 | 显示全部楼层
小茗同学 发表于 2017-11-29 10:35
首先我觉得二楼的鱼油回答的已经很好了,我这里补充两点
1、通过实际操作count = eachline.count(rep_word ...

刚刚做029课昨晚,一直不明白,看了你的答案很不错。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-12-17 14:41:49 | 显示全部楼层
感谢大神们
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-12-17 16:17:34 | 显示全部楼层
小莱 发表于 2016-9-23 22:15
学到 三十出头 零基础的真的感觉有点困难了

兄弟,我不是来帮你解答的,我是来鼓励你的,我也是最近一个月才开始学的,真正的零基础,难懂的地方我也遇到过很多,有一些解决了,有一些就跳过了,但是大部分不懂得都可以通过论坛求助来解决,以后学着学着那些不懂得可能就突然哪天懂了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-10-15 16:25:46 | 显示全部楼层
count函数在python中用法就是返回子字符串在字符串中出现的次数,故不用+
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-18 07:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表