|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
def save_file(boy,girl,count):
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()
def split_file(file_name):
count = 1
boy = []
girl = []
f = open(file_name)
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:
save_file(boy,girl,count)
boy = []
girl = []
count +=1
save_file(boy,girl,count)
f.close()
我按照课本8.1的要求,抄写了这段程序,科室在编译的时候 (role,line_spoken) = each_line.split(":") 这一行始终编译不过去,报这样的问题(role,line_spoken) = each_line.split(":")
ValueError: too many values to unpack (expected 2),请问大神们这是哪里出错了吗?
本帖最后由 sunrise085 于 2020-3-24 16:02 编辑
错误不在split
在上一行
if each_line[:6] != '== == ==':
这句判断,不等号右侧字符串写错了,应该是'======'你在等号中间添加了空格
若修改这个错误后还有同样的问题,那么就要去看一下文件了。很淡是文件中的冒号和你在split中的冒号不一样
需要检查所有的冒号
|
|