tianyamingyue 发表于 2020-3-16 21:02:00

29课的课堂练习

小甲鱼讲的的例子我运行后怎么出现错误
f = open('d:\\1.txt')#我的文件在d盘,所以这里改了一下路径。

boy = []
girl = []
count = 1

for each_line in f:
    if each_line[:6] != '======':
      (role, line_spoken) = each_line.split(':', 1)
      if role == '小甲鱼':
            boy.append(line_spoken)
      if role == '小客服':
            girl.append(line_spoken)
    else:
      file_name_boy = 'boy_' + str(count) + '.txt'
      file_name_girl = 'girl_' + str(count) + '.txt'

      boy_file = open(file_name_boy, 'w')
      girl_file = open(file_name_girl, 'w')

      boy_file.writelines(boy)
      girl_file.writelines(girl)

      boy_file.close()
      girl_file.close()

      boy = []
      girl = []
      count += 1

file_name_boy = 'boy_' + str(count) + '.txt'
file_name_girl = 'girl_' + str(count) + '.txt'

boy_file = open(file_name_boy, 'w')
girl_file = open(file_name_girl, 'w')

boy_file.writelines(boy)
girl_file.writelines(girl)

boy_file.close()
girl_file.close()

f.close()
Traceback (most recent call last):
File "C:/Users/Administrator/AppData/Local/Programs/Python/Python38/123.py", line 9, in <module>
    (role, line_spoken) = each_line.split(':', 1)
ValueError: not enough values to unpack (expected 2, got 1)
这是什么原因?

sunrise085 发表于 2020-3-16 21:07:35

本帖最后由 sunrise085 于 2020-3-16 21:08 编辑

这个错误说明切片没成功。
原因可能是程序中切片欧诺个的冒号和txt文件中的冒号不一样。
是不是txt中用的是中文的冒号,而程序中是英文的冒号?

jackz007 发表于 2020-3-16 21:12:33

      'D:\\1.txt' 中只允许有两种行存在:
1.文本行:行内至少有1个西文的冒号 ':' ;
2.分隔行:开头的 6 个字符必须是'######' ;
      除了这两种行,如果有第三种行存在(比如空行),那就一定会出错。
      按这个要求检查一下你的文件。

zltzlt 发表于 2020-3-17 13:07:45

把你的文件内容发上来,有助于别人分析

tianyamingyue 发表于 2020-3-17 20:36:27

sunrise085 发表于 2020-3-16 21:07
这个错误说明切片没成功。
原因可能是程序中切片欧诺个的冒号和txt文件中的冒号不一样。
是不是txt中用的 ...

不是,我换了中文冒号,或者粘贴都不行。把文章单句直接复制过来分割没问题,一加循环就出错。

tianyamingyue 发表于 2020-3-17 20:38:30

zltzlt 发表于 2020-3-17 13:07
把你的文件内容发上来,有助于别人分析

文件就是29课小甲鱼提供的的那个与客服的对话。
小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦??
小客服:我跟她说你有女朋友了!
小甲鱼:。。。。。。
小客服:她让你分手后考虑下她!然后我说:"您要买个优盘,我就帮您留意下~"
小甲鱼:然后呢?
小客服:她买了两个,说发一个货就好~
小甲鱼:呃。。。。。。你真牛!
小客服:那是,谁让我是鱼C最可爱小客服嘛~
小甲鱼:下次有人想调戏你我不阻止~
小客服:滚!!!
================================================================================
小客服:小甲鱼,有个好评很好笑哈。
小甲鱼:哦?
小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~"
小甲鱼:哈哈哈,我看到丫,我还发微博了呢~
小客服:嗯嗯,我看了你的微博丫~
小甲鱼:哟西~
小客服:那个有条回复“左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡,so easy ^_^”
小甲鱼:T_T
================================================================================
小客服:小甲鱼,今天一个会员想找你
小甲鱼:哦?什么事?
小客服:他说你一个学生月薪已经超过12k了!!
小甲鱼:哪里的?
小客服:上海的
小甲鱼:那正常,哪家公司?
小客服:他没说呀。
小甲鱼:哦
小客服:老大,为什么我工资那么低啊??是时候涨涨工资了!!
小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。
小客服:滚!!!

sunrise085 发表于 2020-3-17 20:39:54

tianyamingyue 发表于 2020-3-17 20:36
不是,我换了中文冒号,或者粘贴都不行。把文章单句直接复制过来分割没问题,一加循环就出错。

单句复制过来分割没问题?加上循环就出问题?
每个单句都尝试了?
估计你没有都尝试吧。只要有一行中的冒号有问题,就会出错。

tianyamingyue 发表于 2020-3-17 20:48:22

sunrise085 发表于 2020-3-17 20:39
单句复制过来分割没问题?加上循环就出问题?
每个单句都尝试了?
估计你没有都尝试吧。只要有一行中的 ...

我全部用替换成英文的冒号了,问题还是没变化

sunrise085 发表于 2020-3-17 21:23:03

tianyamingyue 发表于 2020-3-17 20:48
我全部用替换成英文的冒号了,问题还是没变化

你确定还是那个问题吗?
我刚刚那你的代码可txt都复制下来试了一下。只有一个问题,就是我这里的txt需要以utf-8的编码方式打开,其他的没有问题。
f = open('d:\\1.txt',encoding='utf-8')

tianyamingyue 发表于 2020-3-17 21:39:57

好了,我搞清楚了,是最后一句少了一个冒号,导致的。二楼说的靠谱,没有冒号,切片失败,报错的。搞了我两个晚上。
页: [1]
查看完整版本: 29课的课堂练习