鱼C论坛

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

[技术交流] Python FAQ 033 文件读取错误

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

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

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

x
本帖最后由 qiuyouzhi 于 2020-4-11 09:03 编辑

Python FAQ 033:文件读取错误


问题:

文件内容:
  1. 小客服:小甲鱼,今天有客户问你有没有女朋友?
  2. 小甲鱼:咦??
  3. 小客服:我跟她说你有女朋友了!
  4. 小甲鱼:。。。。。。
  5. 小客服:她让你分手后考虑下她!然后我说:"您要买个优盘,我就帮您留意下~"
  6. 小甲鱼:然后呢?
  7. 小客服:她买了两个,说发一个货就好~
  8. 小甲鱼:呃。。。。。。你真牛!
  9. 小客服:那是,谁让我是鱼C最可爱小客服嘛~
  10. 小甲鱼:下次有人想调戏你我不阻止~
  11. 小客服:滚!!!
  12. ================================================================================
  13. 小客服:小甲鱼,有个好评很好笑哈。
  14. 小甲鱼:哦?
  15. 小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~"
  16. 小甲鱼:哈哈哈,我看到丫,我还发微博了呢~
  17. 小客服:嗯嗯,我看了你的微博丫~
  18. 小甲鱼:哟西~
  19. 小客服:那个有条回复“左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡,so easy ^_^”
  20. 小甲鱼:T_T
  21. ================================================================================
  22. 小客服:小甲鱼,今天一个会员想找你
  23. 小甲鱼:哦?什么事?
  24. 小客服:他说你一个学生月薪已经超过12k了!!
  25. 小甲鱼:哪里的?
  26. 小客服:上海的
  27. 小甲鱼:那正常,哪家公司?
  28. 小客服:他没说呀。
  29. 小甲鱼:哦
  30. 小客服:老大,为什么我工资那么低啊??是时候涨涨工资了!!
  31. 小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。
  32. 小客服:滚!!!
复制代码


代码:

  1. import pickle

  2. f = open('record.txt', encoding = "utf-8")
  3. list1 = []
  4. list2 = []
  5. count = 1

  6. for each_line in f:
  7.     name,tell = each_line.split(':', 1)
  8.     if name == '小甲鱼':
  9.         list1.append(tell)
  10.     elif name == '小客服':
  11.         list2.append(tell)
  12.     else:
  13.         file_name_boy = 'boy_' + str(count) + '.txt'
  14.         f1 = open(file_name_boy,'wb')
  15.         file_name_girl = 'girl' + str(count) + '.txt'
  16.         f2 = open(file_name_girl,'wb')
  17.         pickle.dump(list1,f1)
  18.         pickle.dump(list2,f2)
  19.         f1.close()
  20.         f2.close()
  21. print(list1)
  22. print(list2)

  23. f.close()
复制代码


为什么会报错:

  1. Traceback (most recent call last):
  2.   File "C:\Users\rzzl\Desktop\asd.py", line 9, in <module>
  3.     name,tell = each_line.split(':', 1)
  4. ValueError: not enough values to unpack (expected 2, got 1)
复制代码


解答:

是因为文件中有没有冒号的行(比如====分割线和空行)

这里给出两种解决办法:

1:try-except,直接捕获错误(在for循环的开头)

try里面写split,如果报错就continue.

2:直接硬性判断,如果遍历到的那一行里没有冒号就continue。

代码:

这里我用的是第二种解决办法:

  1. import pickle

  2. f = open('record.txt', encoding = "utf-8")
  3. list1 = []
  4. list2 = []
  5. count = 1

  6. for each_line in f:
  7.     if ':' not in each_line:
  8.         continue
  9.     name,tell = each_line.split(':', 1)
  10.     if name == '小甲鱼':
  11.         list1.append(tell)
  12.     elif name == '小客服':
  13.         list2.append(tell)
  14.     else:
  15.         file_name_boy = 'boy_' + str(count) + '.txt'
  16.         f1 = open(file_name_boy,'wb')
  17.         file_name_girl = 'girl' + str(count) + '.txt'
  18.         f2 = open(file_name_girl,'wb')
  19.         pickle.dump(list1,f1)
  20.         pickle.dump(list2,f2)
  21.         f1.close()
  22.         f2.close()
  23. print(list1)
  24. print(list2)

  25. f.close()
复制代码

本帖被以下淘专辑推荐:

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

使用道具 举报

发表于 2020-8-10 18:56:46 | 显示全部楼层
想请教一下您,我的运行您的代码后出现两个文件boy1和girl1,打开都是“&#896;煝&#11776;”,这是什么原因呀
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-20 13:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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