鱼C论坛

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

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

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

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

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

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


  1. line 17, in f_word
  2.     q = list(p)
  3. UnicodeDecodeError: 'gbk' codec can't decode byte 0x9d in position 8: illegal multibyte sequence
  4. >>>
复制代码

这个是代码(有点潦草)麻烦大家了

  1. def f_word(road,name):
  2.     list1 = []
  3.     import os
  4.     f = list(os.walk(road))
  5.     length = len(f)
  6.     for e in range(length):
  7.         if f[e][1] == []:
  8.             list1 = f[e][2]
  9.         else:
  10.             list1 = f[e][1]
  11.         for v in list1:
  12.             y = os.path.splitext(v)
  13.             i = y[1]
  14.             if i == '.txt':
  15.                 l = os.path.join(f[e][0],v)
  16.                 p = open(l,'r')
  17.                 q = list(p)
  18.                 if name in q:
  19.                     count = q.index(name)
  20.                     if input('请问是否需要打印关键字【'+name+'】在文件的具体位置(yes/no):') == 'yes':
  21.                         print('在文件【%s】中找到关键字【%s】'%(f[e][0],name))


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

复制代码


最佳答案
2020-4-5 21:30:25
是的,试试这样:

  1. def f_word(road, name):
  2.     list1 = []
  3.     import os
  4.     f = list(os.walk(road))
  5.     length = len(f)
  6.     for e in range(length):
  7.         if f[e][1] == []:
  8.             list1 = f[e][2]
  9.         else:
  10.             list1 = f[e][1]
  11.         for v in list1:
  12.             y = os.path.splitext(v)
  13.             i = y[1]
  14.             if i == '.txt':
  15.                 l = os.path.join(f[e][0], v)
  16.                 p = open(l, 'r', encoding="utf-8")
  17.                 q = list(p)
  18.                 if name in q:
  19.                     count = q.index(name)
  20.                     if input('请问是否需要打印关键字【' + name + '】在文件的具体位置(yes/no):') == 'yes':
  21.                         print('在文件【%s】中找到关键字【%s】' % (f[e][0], name))

  22.                 p.close()


  23. a = input('输入路径:')
  24. b = input('请输入要查找的字符:')
  25. f_word(a, b)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-5 21:30:25 | 显示全部楼层    本楼为最佳答案   
是的,试试这样:

  1. def f_word(road, name):
  2.     list1 = []
  3.     import os
  4.     f = list(os.walk(road))
  5.     length = len(f)
  6.     for e in range(length):
  7.         if f[e][1] == []:
  8.             list1 = f[e][2]
  9.         else:
  10.             list1 = f[e][1]
  11.         for v in list1:
  12.             y = os.path.splitext(v)
  13.             i = y[1]
  14.             if i == '.txt':
  15.                 l = os.path.join(f[e][0], v)
  16.                 p = open(l, 'r', encoding="utf-8")
  17.                 q = list(p)
  18.                 if name in q:
  19.                     count = q.index(name)
  20.                     if input('请问是否需要打印关键字【' + name + '】在文件的具体位置(yes/no):') == 'yes':
  21.                         print('在文件【%s】中找到关键字【%s】' % (f[e][0], name))

  22.                 p.close()


  23. a = input('输入路径:')
  24. b = input('请输入要查找的字符:')
  25. f_word(a, b)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

是的是的,谢谢。这效率真棒,十分感谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-21 05:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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