python 30课习题 小甲鱼腌制文件源代码报错,求详解
又报错了,求详解'''Traceback (most recent call last):
File "C:/Users/admin/AppData/Local/Programs/Python/Python39/30.腌制文件.py", line 40, in <module>
split_file('record.txt')
File "C:/Users/admin/AppData/Local/Programs/Python/Python39/30.腌制文件.py", line 25, in split_file
(role, line_spoken) = each_line.split(':', 1)
ValueError: not enough values to unpack (expected 2, got 1)'''
#小甲鱼源代码
import pickle
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, 'wb') # 记得一定要加 b 吖
girl_file = open(file_name_girl, 'wb') # 记得一定要加 b 吖
pickle.dump(boy, boy_file)
pickle.dump(girl, girl_file)
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()
split_file('record.txt')
报错是说each_line用":"切片的时候,只得到了一片,不能赋值给两个元素。就是说你的这一行没有这个冒号,导致分组失败,无法得到两个字符串分别赋值给 role 和 line_spoken
查找问题的方向:1、你的txt文件中有多余的空行,一般在文件末尾;2、文件的某一行或某些行的冒号与你的程序中split使用的冒号不一致,很可能是中英文的冒号混用了
你搜索一下论坛,你的这个问题特别普遍 本帖最后由 Peteryo01223 于 2021-1-29 13:58 编辑
我的标注如下,请参考。我也曾在 txt 文档中,出现中文冒号:,导致 split 语句运行出错,应用英文冒号:。
import pickle
def save_file(boy, girl, count):
file_name_boy = 'boy_' + str(count) + '.txt' # 首先对三个boy的文本进行命名
file_name_girl = 'girl_' + str(count) + '.txt' # 同时对三个girl的文本进行命名
boy_file = open(file_name_boy, 'wb')
# open() 函数用于打开一个文件,创建 file 对象。记得一定要加 wb
girl_file = open(file_name_girl, 'wb')
pickle.dump(boy, boy_file)
# pickle.dump(obj, file, protocol)
# obj 是序列化对象,将对象obj保存到文件file中去
# file 是表示保存到的类文件对象
# protocol 是序列化模式,默认是 0(ASCII协议,表示以文本的形式进行序列化)
pickle.dump(girl, girl_file)
boy_file.close()
girl_file.close()
def split_file(file_name):
# 定义一个函数,为了从目标文件中顺利拆分出上面函数中需要的 boy 和 girl 的值
count = 1 # 设定一个变量,起始值为 1
boy = [] # 定义一个叫 boy 的空列表
girl = [] # 定义一个叫 girl 的空列表
f = open(file_name)
# 打开目标文件
for each_line in f:
if each_line[:6] != '======': # 判断一下,如果不是六个=等号开头
(role, line_spoken) = each_line.split(':', 1)
# 对 each_line 进行拆分,以英文的冒号:为界,拆分一次
# 拆后,分别赋值给 role 和 line_spoken
if role == '小甲鱼': # 如果前面部分是小甲鱼
boy.append(line_spoken) # 那么后面的部分放入列表 boy
if role == '小客服': # 如果前面部分是小客服
girl.append(line_spoken) # 那么后面的部分放入列表 girl
else: # 其他情况,即如是六个=等号开头,也就是遇到了题目中提到的分割的情况,本轮操作结束
save_file(boy, girl, count) # 那么,就把两个列表和一个值放入上面定义好的函数里,运行出结果
boy = [] # 恢复空列表 boy, 为后面的运行做好准备
girl = [] # 恢复空列表 girl, 为后面的运行做好准备
count += 1 # 由于有了上一轮操作了,那么在继续前,把 count 的值主动加1
# 以上程序会一直扫过txt文件的整个文本的每一行,直至最后一行
save_file(boy, girl, count)
# 这一行,是因为 txt 里分割=等号出现在第1/2段之间,和第2/3段之间,第三段末尾没写=等号符
f.close() # 关闭文件,确保保存入硬盘,不至于由于断电而丢失在缓存中的文档
split_file('record.txt') # 使用第二个函数,打开目标文件 record.txt
页:
[1]