一个任务课件--自己写得代码报错
f = open("E:\\推土机\\课后答案\\record.txt")boy = []
girl = []
count = 1
for each_line in f:
if each_line != "============":
#字符串分隔
= 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("E:\\推土机\\课后答案\\第29讲:文件:一个任务课后测试题及答案\\file_name_boy","w")
girl_file = open("E:\\推土机\\课后答案\\第29讲:文件:一个任务课后测试题及答案\\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("E:\\推土机\\课后答案\\第29讲:文件:一个任务课后测试题及答案\\file_name_boy","w")
girl_file = open("E:\\推土机\\课后答案\\第29讲:文件:一个任务课后测试题及答案\\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 "E:\推土机\课后答案\第29讲:文件:一个任务课后测试题及答案\test1.py", line 9, in <module>
= each_line.split(":",1)
ValueError: not enough values to unpack (expected 2, got 1)
这句话的意思是说参数不够,通常情况下就是找不到你的分割符 小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦??
小客服:我跟她说你有女朋友了!
小甲鱼:。。。。。。
小客服:她让你分手后考虑下她!然后我说:"您要买个优盘,我就帮您留意下~"
小甲鱼:然后呢?
小客服:她买了两个,说发一个货就好~
小甲鱼:呃。。。。。。你真牛!
小客服:那是,谁让我是鱼C最可爱小客服嘛~
小甲鱼:下次有人想调戏你我不阻止~
小客服:滚!!!
================================================================================
小客服:小甲鱼,有个好评很好笑哈。
小甲鱼:哦?
小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~"
小甲鱼:哈哈哈,我看到丫,我还发微博了呢~
小客服:嗯嗯,我看了你的微博丫~
小甲鱼:哟西~
小客服:那个有条回复“左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡,so easy ^_^”
小甲鱼:T_T
================================================================================
小客服:小甲鱼,今天一个会员想找你
小甲鱼:哦?什么事?
小客服:他说你一个学生月薪已经超过12k了!!
小甲鱼:哪里的?
小客服:上海的
小甲鱼:那正常,哪家公司?
小客服:他没说呀。
小甲鱼:哦
小客服:老大,为什么我工资那么低啊??是时候涨涨工资了!!
小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。
小客服:滚!!!
这不是有分隔符吗 代码小白liu 发表于 2021-2-28 18:26
小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦??
小客服:我跟她说你有女朋友了!
第7行
if each_line != "============":
总是成立的,因为each_line代表一整行,但是没有哪一行是等于12个字符的"============",也就是不管有没有":"号都会执行分割,导致第9行在以:号分割================================================================================的时候分割出来只有一个值,没有足够的结果赋值给role,line_spoken两个变量,所以报错。
改成这样就可以了,不过你的代码还有其他逻辑问题,应该不能实现你想要的结果
f = open("E:\\推土机\\课后答案\\record.txt")
boy = []
girl = []
count = 1
for each_line in f:
if each_line[:12] != "============":
# 字符串分隔
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(
"E:\\推土机\\课后答案\\第29讲:文件:一个任务课后测试题及答案\\file_name_boy", "w"
)
girl_file = open(
"E:\\推土机\\课后答案\\第29讲:文件:一个任务课后测试题及答案\\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("E:\\推土机\\课后答案\\第29讲:文件:一个任务课后测试题及答案\\file_name_boy", "w")
girl_file = open("E:\\推土机\\课后答案\\第29讲:文件:一个任务课后测试题及答案\\file_name_girl", "w")
boy_file.writelines(boy)
girl_file.writelines(girl)
boy_file.close()
girl_file.close()
f.close()
页:
[1]