鱼C论坛

 找回密码
 立即注册
查看: 643|回复: 2

[已解决]这个出错类型是因为编码问题吗

[复制链接]
发表于 2020-4-5 21:28:10 | 显示全部楼层 |阅读模式

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

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

x
这是显示的错误的原因,是因为编码问题吗??不太懂啊

line 17, in f_word
    q = list(p)
UnicodeDecodeError: 'gbk' codec can't decode byte 0x9d in position 8: illegal multibyte sequence
>>> 
这个是代码(有点潦草)麻烦大家了
def f_word(road,name):
    list1 = []
    import os
    f = list(os.walk(road))
    length = len(f)
    for e in range(length):
        if f[e][1] == []:
            list1 = f[e][2]
        else:
            list1 = f[e][1]
        for v in list1:
            y = os.path.splitext(v)
            i = y[1]
            if i == '.txt':
                l = os.path.join(f[e][0],v)
                p = open(l,'r')
                q = list(p)
                if name in q:
                    count = q.index(name)
                    if input('请问是否需要打印关键字【'+name+'】在文件的具体位置(yes/no):') == 'yes':
                        print('在文件【%s】中找到关键字【%s】'%(f[e][0],name))


                p.close()
a = input('输入路径:')
b = input('请输入要查找的字符:')
f_word(a,b)

最佳答案
2020-4-5 21:30:25
是的,试试这样:
def f_word(road, name):
    list1 = []
    import os
    f = list(os.walk(road))
    length = len(f)
    for e in range(length):
        if f[e][1] == []:
            list1 = f[e][2]
        else:
            list1 = f[e][1]
        for v in list1:
            y = os.path.splitext(v)
            i = y[1]
            if i == '.txt':
                l = os.path.join(f[e][0], v)
                p = open(l, 'r', encoding="utf-8")
                q = list(p)
                if name in q:
                    count = q.index(name)
                    if input('请问是否需要打印关键字【' + name + '】在文件的具体位置(yes/no):') == 'yes':
                        print('在文件【%s】中找到关键字【%s】' % (f[e][0], name))

                p.close()


a = input('输入路径:')
b = input('请输入要查找的字符:')
f_word(a, b)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-5 21:30:25 | 显示全部楼层    本楼为最佳答案   
是的,试试这样:
def f_word(road, name):
    list1 = []
    import os
    f = list(os.walk(road))
    length = len(f)
    for e in range(length):
        if f[e][1] == []:
            list1 = f[e][2]
        else:
            list1 = f[e][1]
        for v in list1:
            y = os.path.splitext(v)
            i = y[1]
            if i == '.txt':
                l = os.path.join(f[e][0], v)
                p = open(l, 'r', encoding="utf-8")
                q = list(p)
                if name in q:
                    count = q.index(name)
                    if input('请问是否需要打印关键字【' + name + '】在文件的具体位置(yes/no):') == 'yes':
                        print('在文件【%s】中找到关键字【%s】' % (f[e][0], name))

                p.close()


a = input('输入路径:')
b = input('请输入要查找的字符:')
f_word(a, b)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-4-5 21:34:03 | 显示全部楼层
zltzlt 发表于 2020-4-5 21:30
是的,试试这样:

是的是的,谢谢。这效率真棒,十分感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-26 00:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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