鱼C论坛

 找回密码
 立即注册
查看: 1334|回复: 3

[已解决]Python第29讲“全部替换”代码问题

[复制链接]
发表于 2020-6-7 21:33:45 | 显示全部楼层 |阅读模式

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

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

x
第29讲中的全部替换问题,为什么下面代码不对,说是io.UnsupportedOperation: not readable,为什么
def file_replace(file_name,oldword,newword):
    f_read = open(str(file_name),encoding='utf-8')
    count = 0
    for each_line in f_read:
        if oldword in each_line:
            count = count+each_line.count(oldword)
    f_read.close()

    choose = input('\n文件%s中共有%d个【%s】\n是否将将【%s】全部替换为【%s】?\n 【YES/NO】:' % (file_name,count,oldword,oldword,newword))
    if choose in ['YES','yes','Yes']:
        f_write = open(str(file_name),'w',encoding='utf-8')
        for each_line in f_write:
            if oldword in each_line:
                each_line.replace(oldword,newword)
        f_write.close()



file_name = input('请输入文件名:')
oldword = input('请输入需要替换的单词或字符:')
newword = input('请输入新的单词或字符:')
file_replace(file_name, oldword, newword)
最佳答案
2020-6-7 21:39:50
本帖最后由 Twilight6 于 2020-6-7 21:42 编辑

        for each_line in f_write:
            if oldword in each_line:
                each_line.replace(oldword,newword)
你打开是写入打开,不能遍历,你用 writeline 写入可迭代对象就好了:
正确代码:
def file_replace(file_name,oldword,newword):
    f_read = open(str(file_name),encoding='utf-8')
    count = 0
    content = []
    for each_line in f_read:
        if oldword in each_line:
            content.append(each_line.replace(oldword, newword))
            count = count+each_line.count(oldword)
    f_read.close()

    choose = input('\n文件%s中共有%d个【%s】\n是否将将【%s】全部替换为【%s】?\n 【YES/NO】:' % (file_name,count,oldword,oldword,newword))
    if choose in ['YES','yes','Yes']:
        f_write = open(file_name,'w',encoding='utf-8')
        f_write.writelines(content)
        f_write.close()



file_name = input('请输入文件名:')
oldword = input('请输入需要替换的单词或字符:')
newword = input('请输入新的单词或字符:')
file_replace(file_name, oldword, newword)

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

使用道具 举报

发表于 2020-6-7 21:37:40 | 显示全部楼层
f_read = open(str(file_name), ‘r’, encoding='utf-8')
可能是这样的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-7 21:39:50 | 显示全部楼层    本楼为最佳答案   
本帖最后由 Twilight6 于 2020-6-7 21:42 编辑

        for each_line in f_write:
            if oldword in each_line:
                each_line.replace(oldword,newword)
你打开是写入打开,不能遍历,你用 writeline 写入可迭代对象就好了:
正确代码:
def file_replace(file_name,oldword,newword):
    f_read = open(str(file_name),encoding='utf-8')
    count = 0
    content = []
    for each_line in f_read:
        if oldword in each_line:
            content.append(each_line.replace(oldword, newword))
            count = count+each_line.count(oldword)
    f_read.close()

    choose = input('\n文件%s中共有%d个【%s】\n是否将将【%s】全部替换为【%s】?\n 【YES/NO】:' % (file_name,count,oldword,oldword,newword))
    if choose in ['YES','yes','Yes']:
        f_write = open(file_name,'w',encoding='utf-8')
        f_write.writelines(content)
        f_write.close()



file_name = input('请输入文件名:')
oldword = input('请输入需要替换的单词或字符:')
newword = input('请输入新的单词或字符:')
file_replace(file_name, oldword, newword)

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

使用道具 举报

发表于 2021-4-25 19:16:29 | 显示全部楼层
7。8段貌似有点问题吧。。。。。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-16 00:08

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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