“一个任务”那里照抄代码我都不会,来个大佬看一下
Traceback (most recent call last):File "C:\Users\ccj\Desktop\python\p2_16(1).py", line 5, in <module>
for each_line in f:
UnicodeDecodeError: 'gbk' codec can't decode byte 0xae in position 4: illegal multibyte sequence
代码
f=open('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.close()
girl_file.close()
boy=[]
girl=[]
count+=1
f.close() f=open('record.txt',encoding="utf-8")
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',encoding="utf-8")
girl_file=open(file_name_girl,'w',encoding="utf-8")
boy_file.writelines(boy)
girl_file.writelines(girl)
boy_file.close()
girl_file.close()
boy=[]
girl=[]
count+=1
f.close()
首先你要保证,你文本 record.txt 中冒号都是英文冒号,以防万一这里拷贝去重新测试吧:
小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦? ?
小客服:我跟她说你有女朋友了!
小客服:她让你分手后考虑下她!然后我说: "您要买个优盘,我就帮您留意下~"
小甲鱼:然后呢?
小客服:她买了两个,说发一个货就好~
小甲鱼:呃。。。。。。你真牛!
小客服:那是,谁让我是鱼C最可爱小客服嘛~
小甲鱼:下次有人想调戏你我不阻止~
小客服:滚! ! !
================================================================================
小客服:小甲鱼,有个好评很好笑哈。
小甲鱼:哦?
小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~”
小甲鱼:哈哈哈, 我看到丫A我还发微博了呢~
小客服:嗯嗯,我看了你的微博丫~
小甲鱼:哟西~
小客服:那个有条回复"左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡, so easy^. ^”
小甲鱼:T_T
================================================================================
小客服:小甲鱼,今天- -个会员想找你
小甲鱼:哦?什么事?
小客服:他说你- -个学生月薪已经超过12k了! !
小甲鱼:哪里的?
小客服:上海的
小甲鱼:那正常,哪家公司?
小客服:他没说呀。
小甲鱼:哦
小客服:老大,为什么我工资那么低啊? ?是时候涨涨工资了! !
小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。
小客服:滚! ! !
然后你你这代码少了小甲鱼和小客服的字符,加上去,然后 open 上加上个参数 encoding = 'utf-8' 即可:
f=open('record.txt',encoding='utf-8')
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
f.close() Twilight6 发表于 2020-8-21 14:34
首先你要保证,你文本 record.txt 中冒号都是英文冒号,以防万一这里拷贝去重新测试吧:
谢谢大佬^_^
页:
[1]