30文件系统第四题
{:5_100:} 请将该脚本放于待查找的文件夹内,请输入关键字:小甲鱼请问是否需要打印关键字【小甲鱼】在文件中的具体位置(YES/NO):yes
Traceback (most recent call last):
File "d:/learn/新版教学视频小甲鱼/30文件系统.py/关键字搜索.py", line 131, in <module>
search_files(key, detail)
File "d:/learn/新版教学视频小甲鱼/30文件系统.py/关键字搜索.py", line 121, in search_files
key_dict = search_in_file(each_txt_file, key)
File "d:/learn/新版教学视频小甲鱼/30文件系统.py/关键字搜索.py", line 99, in search_in_file
for each_line in f:
File "C:\Users\Admin\AppData\Local\Programs\Python\Python38\lib\codecs.py", line 322, in decode
(result, consumed) = self._buffer_decode(data, self.errors, final)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xd0 in position 76: invalid continuation byte
运行结果是这样的,加了解码格式也不行,这是为啥哦,大佬们
我是用的参考答案,自己是真的写不出来{:5_99:} 本帖最后由 jackz007 于 2021-2-21 19:16 编辑
需要求助,关键的关键,是必须贴出代码!!! 源代码贴出来 jackz007 发表于 2021-2-21 19:14
关键的关键,是必须贴出代码!!!
import os
def print_pos(key_dict):
# 定义一个打印位置的函数,参数为一个键的字典
keys = key_dict.keys()
keys = sorted(keys)# 由于字典是无序的,我们这里对行数进行排序
for each_key in keys:
print('关键字出现在第 %s 行,第 %s 个位置。' % (each_key, str(key_dict)))
def pos_in_line(line, key):
pos = []
begin = line.find(key)
while begin != -1:
pos.append(begin + 1)# 用户的角度是从1开始数
begin = line.find(key, begin+1)# 从下一个位置继续查找
return pos
def search_in_file(file_name, key):
f = open(file_name, encoding='UTF-8')
count = 0# 记录行数
key_dict = dict()# 字典,用户存放key所在具体行数对应具体位置
for each_line in f:
count += 1
if key in each_line:
pos = pos_in_line(each_line, key)# key在每行对应的位置
key_dict = pos
f.close()
return key_dict
def search_files(key, detail):
# all_files = os.walk(os.getcwd())
all_files = os.walk('D:\\learn')
txt_files = []
for i in all_files:
for each_file in i:
if os.path.splitext(each_file) == '.txt':# 根据后缀判断是否文本文件
each_file = os.path.join(i, each_file)
txt_files.append(each_file)
for each_txt_file in txt_files:
key_dict = search_in_file(each_txt_file, key)
if key_dict:
print('================================================================')
print('在文件【%s】中找到关键字【%s】' % (each_txt_file, key))
if detail in ['YES', 'Yes', 'yes']:
print_pos(key_dict)
key = input('请将该脚本放于待查找的文件夹内,请输入关键字:')
detail = input('请问是否需要打印关键字【%s】在文件中的具体位置(YES/NO):' % key)
search_files(key, detail)
就和参考答案一样,因为自己实在做不出来。只不过我是想在d盘执行 jackz007 发表于 2021-2-21 19:14
需要求助,关键的关键,是必须贴出代码!!!
{:5_100:}马上贴代码上来 我这里运行没问题
估计是f = open(file_name, encoding='UTF-8')这里的问题。去掉 encoding='UTF-8'调试看看 redforce 发表于 2021-2-21 19:25
我这里运行没问题
估计是f = open(file_name, encoding='UTF-8')这里的问题。去掉 encoding='UTF-8'调试看 ...
UnicodeDecodeError: 'gbk' codec can't decode byte 0xbc in position 25: illegal multibyte sequence redforce 发表于 2021-2-21 19:25
我这里运行没问题
估计是f = open(file_name, encoding='UTF-8')这里的问题。去掉 encoding='UTF-8'调试看 ...
一样的错误我去掉之后 redforce 发表于 2021-2-21 19:25
我这里运行没问题
估计是f = open(file_name, encoding='UTF-8')这里的问题。去掉 encoding='UTF-8'调试看 ...
之前就是因为这个错误我才尝试加入解码的 python_aini 发表于 2021-2-21 21:16
之前就是因为这个错误我才尝试加入解码的
有试过 encoding = 'gbk' 吗 Daniel_Zhang 发表于 2021-2-21 21:27
有试过 encoding = 'gbk' 吗
UnicodeDecodeError: 'gbk' codec can't decode byte 0xbc in position 25: illegal multibyte sequence
{:5_99:}还是一样的。 python_aini 发表于 2021-2-21 22:08
UnicodeDecodeError: 'gbk' codec can't decode byte 0xbc in position 25: illegal multibyte sequence
...
试试 try except?{:10_245:} Daniel_Zhang 发表于 2021-2-21 22:34
试试 try except?
try except只能是把出错的内容改了,但不能将程序的结果弄出来呀{:5_99:}0.0 python_aini 发表于 2021-2-21 23:02
try except只能是把出错的内容改了,但不能将程序的结果弄出来呀0.0
看看是不是有特列的文件{:10_277:}
我这里运行的不报错,但是找不到对应的字符
应该是有 bug{:10_250:} Daniel_Zhang 发表于 2021-2-21 23:14
看看是不是有特列的文件
我这里运行的不报错,但是找不到对应的字符
我再找找看{:5_98:} 本帖最后由 Stubborn 于 2021-2-22 01:03 编辑
这个是文件有问题,我记得刚学的时候也遇到过。
记得好像是新建一个文件,把文字复制粘贴到新的文件里面,替换下文件源。
或者尝试使用二进制模式‘rt’打开文件 Stubborn 发表于 2021-2-22 01:01
这个是文件有问题,我记得刚学的时候也遇到过。
记得好像是新建一个文件,把文字复制粘贴到新的文件里面, ...
{:5_99:}依旧是一样的错误,应该是我的文件后缀名的问题,或者米有后缀名造成的无法解码 python_aini 发表于 2021-2-22 19:01
依旧是一样的错误,应该是我的文件后缀名的问题,或者米有后缀名造成的无法解码
是不是有 binary 格式写入的.txt文件{:10_257:}
新建一个路径,加入一个txt 文件看看 Daniel_Zhang 发表于 2021-2-22 19:13
是不是有 binary 格式写入的.txt文件
新建一个路径,加入一个txt 文件看看
真的是这样,我重新规划了一个路径,单独存放了一个txt文件就ok了{:5_95:},666兄弟
页:
[1]