分割对话总是报错
f=open('E:\\普通文本.txt',encoding='UTF-8')#打开文件boy = []
girl = [] #将boy和girl说 的话弄成列表
count = 1
for each_line in f: #每一句在f文件中的话
if each_line[:6] != '======':
(role,line_spoken) = each_line.split(':',1)#role(人物),说的话,每行都分割(split),‘:’表示从冒号开始,分割一次
if role == '我': #如果人物是小甲鱼:
boy.append(line_spoken)#最开始的boy[] 将line_spoken append(扩展)到里面
if role == '珂儿':
girl.append(line_spoken)
else:
#文件分别保存
file_name_boy = 'boy_'+str(count)+'.txt'#file_name:文件名赋值为'boy_'+str(count)+'.txt' str(count)就是boy_1的1会增加
file_name_girl = 'girl_'+str(count)+'.txt'
boy_file = open('file_name_boy','w')#这一步是以‘w’形式打开boy文件,可写形式
girl_file = open('file_name_girl','w')
boy_file.writelines(boy)#将boy[]和girl[]列表写入boy_file和girl_file
girl_file.writelines(girl)
boy = []
girl = []
count += 1#重新定义boy 和girl count就是那个boy_1的小标count += 1 小标+1
这是照着小甲鱼视频写的,但是总报错
Traceback (most recent call last):
File "D:/学习软件——python/例题/分割文件.py", line 10, in <module>
(role,line_spoken) = each_line.split(':',1)#role(人物),说的话,每行都分割(split),‘:’表示从冒号开始,分割一次
ValueError: not enough values to unpack (expected 2, got 1)
这是报错内容
有没有大佬帮一下忙费点时间看一看怎么改哇{:5_100:}
应该是你的 record.txt 内容和小甲鱼给出的不同,下面是正确的文本内容,你文本的冒号(:)可能用成中文的了:
小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦??
小客服:我跟她说你有女朋友了!
小甲鱼:。。。。。。
小客服:她让你分手后考虑下她!然后我说:"您要买个优盘,我就帮您留意下~"
小甲鱼:然后呢?
小客服:她买了两个,说发一个货就好~
小甲鱼:呃。。。。。。你真牛!
小客服:那是,谁让我是鱼C最可爱小客服嘛~
小甲鱼:下次有人想调戏你我不阻止~
小客服:滚!!!
================================================================================
小客服:小甲鱼,有个好评很好笑哈。
小甲鱼:哦?
小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~"
小甲鱼:哈哈哈,我看到丫,我还发微博了呢~
小客服:嗯嗯,我看了你的微博丫~
小甲鱼:哟西~
小客服:那个有条回复“左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡,so easy ^_^”
小甲鱼:T_T
================================================================================
小客服:小甲鱼,今天一个会员想找你
小甲鱼:哦?什么事?
小客服:他说你一个学生月薪已经超过12k了!!
小甲鱼:哪里的?
小客服:上海的
小甲鱼:那正常,哪家公司?
小客服:他没说呀。
小甲鱼:哦
小客服:老大,为什么我工资那么低啊??是时候涨涨工资了!!
小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。
小客服:滚!!!
自己定义的文本中内容是不是有些错误,比如冒号用成中文字符,或者文件中一些行等号少于 6 个,建议将你的文本发上来,帮你改改文本内容
代码中的错误帮你改完了:
[*]你忘记关闭文件,导致缓存内的字符没有写入文件中去
[*]你的文件名是使用 file_name_boy 的参数,而不是字符串,要把引号去掉,file_name girl 也是一样
f=open('E:\\普通文本.txt',encoding='UTF-8')#打开文件
boy = []
girl = [] #将boy和girl说 的话弄成列表
count = 1
for each_line in f: #每一句在f文件中的话
if each_line[:6] != '======':
(role,line_spoken) = each_line.split(':',1)#role(人物),说的话,每行都分割(split),‘:’表示从冒号开始,分割一次
if role == '我': #如果人物是小甲鱼:
boy.append(line_spoken)#最开始的boy[] 将line_spoken append(扩展)到里面
if role == '珂儿':
girl.append(line_spoken)
else:
#文件分别保存
file_name_boy = 'boy_'+str(count)+'.txt'#file_name:文件名赋值为'boy_'+str(count)+'.txt' str(count)就是boy_1的1会增加
file_name_girl = 'girl_'+str(count)+'.txt'
boy_file = open(file_name_boy,'w')#这一步是以‘w’形式打开boy文件,可写形式
girl_file = open(file_name_girl,'w')
boy_file.writelines(boy)#将boy[]和girl[]列表写入boy_file和girl_file
girl_file.writelines(girl)
boy_file.close()
girl_file.close()
boy = []
girl = []
count += 1#重新定义boy 和girl count就是那个boy_1的小标count += 1 小标+1
f.close() Twilight6 发表于 2020-7-25 10:35
自己定义的文本中内容是不是有些错误,比如冒号用成中文字符,或者文件中一些行等号少于 6 个,建议将 ...
谢谢大哥{:5_109:} zltzlt 发表于 2020-7-25 10:33
应该是你的 record.txt 内容和小甲鱼给出的不同,下面是正确的文本内容,你文本的冒号(:)可能用成中文的 ...
谢谢谢谢{:5_108:}
页:
[1]