|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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)
复制代码
是的,试试这样:
- 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)
复制代码
|
|