huyanmin 发表于 2021-1-29 11:41:04

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')

sunrise085 发表于 2021-1-29 12:00:56

报错是说each_line用":"切片的时候,只得到了一片,不能赋值给两个元素。就是说你的这一行没有这个冒号,导致分组失败,无法得到两个字符串分别赋值给 role 和 line_spoken
查找问题的方向:1、你的txt文件中有多余的空行,一般在文件末尾;2、文件的某一行或某些行的冒号与你的程序中split使用的冒号不一致,很可能是中英文的冒号混用了

你搜索一下论坛,你的这个问题特别普遍

Peteryo01223 发表于 2021-1-29 13:51:56

本帖最后由 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]
查看完整版本: python 30课习题 小甲鱼腌制文件源代码报错,求详解