鱼C论坛

 找回密码
 立即注册
查看: 1167|回复: 1

[已解决]求助

[复制链接]
发表于 2020-7-26 22:32:05 | 显示全部楼层 |阅读模式

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

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

x
import os
list2=[]
def search(name):
    os.chdir(name)
    list1=os.listdir()
    for i in list1:
        if '.txt'  in i:
            name1=os.path.join(os.getcwd(),i)
            list2.append(name1)
        if os.path.isdir(i):
            name=os.path.join(os.getcwd(),i)
            search(name)
def exam(str1):
    count1=0
    count2=0
    list3=[]
    for i in list2:
        f1=open(i,'r',encoding='utf-8')
        if str1 in f1:
         print('在文件【',i,'】中找到关键字【',str1,'】')
         for eachline in f1:
            count1=count1+1
            if str1 in eachline:
                begin=eachline.find(str1)
                while begin != -1:
                    list3.append(begin)
                    begin=eachline.find(str1,begin+1)
            print('关键字出现在第',count1,'第',list3,'个位置。')
str1=input("请将该脚本放于待查找的文件夹内,请输入关键字:")
search('G:\新建文件夹 (4)')
exam(str1)








出现以下问题:
请将该脚本放于待查找的文件夹内,请输入关键字:愿
Traceback (most recent call last):
  File "G:\新建文件夹 (4)\29.py", line 31, in <module>
    exam(str1)
  File "G:\新建文件夹 (4)\29.py", line 19, in exam
    if str1 in f1:
  File "E:\python\lib\codecs.py", line 322, in decode
    (result, consumed) = self._buffer_decode(data, self.errors, final)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xb4 in position 0: invalid start byte
>>>
最佳答案
2020-7-26 22:35:55
本帖最后由 Twilight6 于 2020-7-26 22:37 编辑

[b]


把 open 里面的encoding = 'utf-8' 去掉试试看

如果运行还是报错,那么就说明当前文件夹下不止有一种编码的 txt 文件

建议把这个代码文件拷贝到另一个重新新建的文件夹,然后把 txt 文本按下面操作存放到这个文件夹里放一起

然后将你需要比较的文本重新另存为,按照下面的操作来:

第一步,打开 txt 文件选择另存为:

                               
登录/注册后可看大图



第二步设置编码为 utf-8:


                               
登录/注册后可看大图


然后重新运行代码,这样就不会报错

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

使用道具 举报

发表于 2020-7-26 22:35:55 | 显示全部楼层    本楼为最佳答案   
本帖最后由 Twilight6 于 2020-7-26 22:37 编辑

[b]


把 open 里面的encoding = 'utf-8' 去掉试试看

如果运行还是报错,那么就说明当前文件夹下不止有一种编码的 txt 文件

建议把这个代码文件拷贝到另一个重新新建的文件夹,然后把 txt 文本按下面操作存放到这个文件夹里放一起

然后将你需要比较的文本重新另存为,按照下面的操作来:

第一步,打开 txt 文件选择另存为:

                               
登录/注册后可看大图



第二步设置编码为 utf-8:


                               
登录/注册后可看大图


然后重新运行代码,这样就不会报错

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-19 16:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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