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