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:08 编辑
这个错误说明切片没成功。
原因可能是程序中切片欧诺个的冒号和txt文件中的冒号不一样。
是不是txt中用的是中文的冒号,而程序中是英文的冒号? 'D:\\1.txt' 中只允许有两种行存在:
1.文本行:行内至少有1个西文的冒号 ':' ;
2.分隔行:开头的 6 个字符必须是'######' ;
除了这两种行,如果有第三种行存在(比如空行),那就一定会出错。
按这个要求检查一下你的文件。 把你的文件内容发上来,有助于别人分析 sunrise085 发表于 2020-3-16 21:07
这个错误说明切片没成功。
原因可能是程序中切片欧诺个的冒号和txt文件中的冒号不一样。
是不是txt中用的 ...
不是,我换了中文冒号,或者粘贴都不行。把文章单句直接复制过来分割没问题,一加循环就出错。 zltzlt 发表于 2020-3-17 13:07
把你的文件内容发上来,有助于别人分析
文件就是29课小甲鱼提供的的那个与客服的对话。
小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦??
小客服:我跟她说你有女朋友了!
小甲鱼:。。。。。。
小客服:她让你分手后考虑下她!然后我说:"您要买个优盘,我就帮您留意下~"
小甲鱼:然后呢?
小客服:她买了两个,说发一个货就好~
小甲鱼:呃。。。。。。你真牛!
小客服:那是,谁让我是鱼C最可爱小客服嘛~
小甲鱼:下次有人想调戏你我不阻止~
小客服:滚!!!
================================================================================
小客服:小甲鱼,有个好评很好笑哈。
小甲鱼:哦?
小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~"
小甲鱼:哈哈哈,我看到丫,我还发微博了呢~
小客服:嗯嗯,我看了你的微博丫~
小甲鱼:哟西~
小客服:那个有条回复“左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡,so easy ^_^”
小甲鱼:T_T
================================================================================
小客服:小甲鱼,今天一个会员想找你
小甲鱼:哦?什么事?
小客服:他说你一个学生月薪已经超过12k了!!
小甲鱼:哪里的?
小客服:上海的
小甲鱼:那正常,哪家公司?
小客服:他没说呀。
小甲鱼:哦
小客服:老大,为什么我工资那么低啊??是时候涨涨工资了!!
小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。
小客服:滚!!! tianyamingyue 发表于 2020-3-17 20:36
不是,我换了中文冒号,或者粘贴都不行。把文章单句直接复制过来分割没问题,一加循环就出错。
单句复制过来分割没问题?加上循环就出问题?
每个单句都尝试了?
估计你没有都尝试吧。只要有一行中的冒号有问题,就会出错。
sunrise085 发表于 2020-3-17 20:39
单句复制过来分割没问题?加上循环就出问题?
每个单句都尝试了?
估计你没有都尝试吧。只要有一行中的 ...
我全部用替换成英文的冒号了,问题还是没变化 tianyamingyue 发表于 2020-3-17 20:48
我全部用替换成英文的冒号了,问题还是没变化
你确定还是那个问题吗?
我刚刚那你的代码可txt都复制下来试了一下。只有一个问题,就是我这里的txt需要以utf-8的编码方式打开,其他的没有问题。
f = open('d:\\1.txt',encoding='utf-8') 好了,我搞清楚了,是最后一句少了一个冒号,导致的。二楼说的靠谱,没有冒号,切片失败,报错的。搞了我两个晚上。
页:
[1]