29讲:小甲鱼鱼小客服的split问题
代码如下:f = open('D:\\record.txt')
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.colse()
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.colse()
girl_file.close()
f.colse()
问题反馈:
Traceback (most recent call last):
File "D:\test1.py", line 9, in <module>
(role,line_spoken) = each_line.split(':',1)
ValueError: not enough values to unpack (expected 2, got 1)
什么意思,看着视频敲的啊!求解! 本帖最后由 zltzlt 于 2020-4-4 16:00 编辑
你的文件内容是什么?
close() 拼错了:
boy_file.colse() # 应该是 close() 不是 colse()
girl_file.close()
f.colse() Traceback (most recent call last):
File "D:\test1.py", line 9, in <module>
(role,line_spoken) = each_line.split(':',1)
ValueError: not enough values to unpack (expected 2, got 1) zhou_gyt 发表于 2020-4-4 16:01
Traceback (most recent call last):
File "D:\test1.py", line 9, in
(role,line_spoken) = each ...
文件没有问题? 谢谢 还是这个提示、
文件就是小甲鱼小客服的对话内容:
小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦??
小客服:我跟她说你有女朋友了!
小甲鱼:。。。。。。
小客服:她让你分手后考虑下她!然后我说:"您要买个优盘,我就帮您留意下~"
小甲鱼:然后呢?
小客服:她买了两个,说发一个货就好~
小甲鱼:呃。。。。。。你真牛!
小客服:那是,谁让我是鱼C最可爱小客服嘛~
小甲鱼:下次有人想调戏你我不阻止~
小客服:滚!!!
================================================================================
小客服:小甲鱼,有个好评很好笑哈。
小甲鱼:哦?
小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~"
小甲鱼:哈哈哈,我看到丫,我还发微博了呢~
小客服:嗯嗯,我看了你的微博丫~
小甲鱼:哟西~
小客服:那个有条回复“左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡,so easy ^_^”
小甲鱼:T_T
================================================================================
小客服:小甲鱼,今天一个会员想找你
小甲鱼:哦?什么事?
小客服:他说你一个学生月薪已经超过12k了!!
小甲鱼:哪里的?
小客服:上海的
小甲鱼:那正常,哪家公司?
小客服:他没说呀。
小甲鱼:哦
小客服:老大,为什么我工资那么低啊??是时候涨涨工资了!!
小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。
小客服:滚!!!
网上找的一段代码:
#打开record.txt文件
f = open('D:\\record.txt')
#定义3个变量,并对它们初始化
boy = []
girl = []
count = 1
#循环读取文件
for each_line in f:
#如果当前内容不"======",则继续读取内容;否则读取,开始写操作
if each_line[:6] != "======":
#读取的内容以":"进行分割,分割后分别赋值给元组元素role和spoken
(role,spoken) = each_line.split(':',1)
#如果对话角色为"小甲鱼",则将文件追加到boy列表中
if role == '小甲鱼':
boy.append(spoken)
#如果对话角色为"小客服",则将文件追加到girl列表中
if role == '小客服':
girl.append(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')
#writelines的参数是序列(比如列表),它会迭代帮你写入文件。
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')
#writelines的参数是序列(比如列表),它会迭代帮你写入文件。
boy_file.writelines(boy)
girl_file.writelines(girl)
#关闭文件对象
boy_file.close()
girl_file.close()
#关闭文件对象
f.close()
这个就可以运行。 说明文件没问题 if判断不匹配,切片是几个右边就需要写几个等号:
if each_line[:6] != '======':
(role,line_spoken) = each_line.split(':',1),ValueError: not enough values to unpack (expected 2, got 1),报错的意思是说需要两个值,但是只有一个值,原因是判断的这一行里不包含冒号':'。
问题出在if each_line[:6] != '=====',[:6]是6个字符,你右边有5个'=',所以分割行没有被排除而进入了下面的循环,导致了以上错误。
ValueError: not enough values to unpack 这个错误应该是参数不正确,你文件使用的冒号和代码中的冒号同时英文标点,或者同是中文标点吗? 谢谢8楼,9楼。终于明白了。 txxcat 发表于 2020-4-4 16:16
(role,line_spoken) = each_line.split(':',1),ValueError: not enough values to unpack (expected 2, go ...
谢了
页:
[1]