zhou_gyt 发表于 2020-4-4 15:57:16

29讲:小甲鱼鱼小客服的split问题

代码如下:
f = open('D:\\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.colse()
      girl_file.close()

      boy = []
      girl = []
      count += 1

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.colse()
girl_file.close()


f.colse()
问题反馈:
Traceback (most recent call last):
File "D:\test1.py", line 9, in <module>
    (role,line_spoken) = each_line.split(':',1)
ValueError: not enough values to unpack (expected 2, got 1)
什么意思,看着视频敲的啊!求解!

zltzlt 发表于 2020-4-4 15:58:42

本帖最后由 zltzlt 于 2020-4-4 16:00 编辑

你的文件内容是什么?

close() 拼错了:

boy_file.colse()    # 应该是 close() 不是 colse()
girl_file.close()


f.colse()

zhou_gyt 发表于 2020-4-4 16:01:53

Traceback (most recent call last):
File "D:\test1.py", line 9, in <module>
    (role,line_spoken) = each_line.split(':',1)
ValueError: not enough values to unpack (expected 2, got 1)

qiuyouzhi 发表于 2020-4-4 16:02:27

zhou_gyt 发表于 2020-4-4 16:01
Traceback (most recent call last):
File "D:\test1.py", line 9, in
    (role,line_spoken) = each ...

文件没有问题?

zhou_gyt 发表于 2020-4-4 16:03:06

谢谢 还是这个提示、
文件就是小甲鱼小客服的对话内容:
小客服:小甲鱼,今天有客户问你有没有女朋友?
小甲鱼:咦??
小客服:我跟她说你有女朋友了!
小甲鱼:。。。。。。
小客服:她让你分手后考虑下她!然后我说:"您要买个优盘,我就帮您留意下~"
小甲鱼:然后呢?
小客服:她买了两个,说发一个货就好~
小甲鱼:呃。。。。。。你真牛!
小客服:那是,谁让我是鱼C最可爱小客服嘛~
小甲鱼:下次有人想调戏你我不阻止~
小客服:滚!!!
================================================================================
小客服:小甲鱼,有个好评很好笑哈。
小甲鱼:哦?
小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~"
小甲鱼:哈哈哈,我看到丫,我还发微博了呢~
小客服:嗯嗯,我看了你的微博丫~
小甲鱼:哟西~
小客服:那个有条回复“左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡,so easy ^_^”
小甲鱼:T_T
================================================================================
小客服:小甲鱼,今天一个会员想找你
小甲鱼:哦?什么事?
小客服:他说你一个学生月薪已经超过12k了!!
小甲鱼:哪里的?
小客服:上海的
小甲鱼:那正常,哪家公司?
小客服:他没说呀。
小甲鱼:哦
小客服:老大,为什么我工资那么低啊??是时候涨涨工资了!!
小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。
小客服:滚!!!

zhou_gyt 发表于 2020-4-4 16:04:36

网上找的一段代码:
#打开record.txt文件
f = open('D:\\record.txt')

#定义3个变量,并对它们初始化
boy = []   
girl = []
count = 1

#循环读取文件
for each_line in f:

#如果当前内容不"======",则继续读取内容;否则读取,开始写操作
if each_line[:6] != "======":            
   
    #读取的内容以":"进行分割,分割后分别赋值给元组元素role和spoken
    (role,spoken) = each_line.split(':',1)
   
    #如果对话角色为"小甲鱼",则将文件追加到boy列表中
    if role == '小甲鱼':                  
       boy.append(spoken)
      
    #如果对话角色为"小客服",则将文件追加到girl列表中
    if role == '小客服':                  
       girl.append(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')   
   
   #writelines的参数是序列(比如列表),它会迭代帮你写入文件。
   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(file_name_boy,'w')         
girl_file = open(file_name_girl,'w')

#writelines的参数是序列(比如列表),它会迭代帮你写入文件。   
boy_file.writelines(boy)   
girl_file.writelines(girl)

#关闭文件对象      
boy_file.close()                              
girl_file.close()                  

#关闭文件对象
f.close()   
这个就可以运行。

zhou_gyt 发表于 2020-4-4 16:06:50

说明文件没问题

BngThea 发表于 2020-4-4 16:15:41

if判断不匹配,切片是几个右边就需要写几个等号:
if each_line[:6] != '======':

txxcat 发表于 2020-4-4 16:16:11

(role,line_spoken) = each_line.split(':',1),ValueError: not enough values to unpack (expected 2, got 1),报错的意思是说需要两个值,但是只有一个值,原因是判断的这一行里不包含冒号':'。
问题出在if each_line[:6] != '=====',[:6]是6个字符,你右边有5个'=',所以分割行没有被排除而进入了下面的循环,导致了以上错误。

倒戈卸甲 发表于 2020-4-4 16:16:15

ValueError: not enough values to unpack 这个错误应该是参数不正确,你文件使用的冒号和代码中的冒号同时英文标点,或者同是中文标点吗?

zhou_gyt 发表于 2020-4-4 16:29:22

谢谢8楼,9楼。终于明白了。

zhou_gyt 发表于 2020-4-4 16:30:01

txxcat 发表于 2020-4-4 16:16
(role,line_spoken) = each_line.split(':',1),ValueError: not enough values to unpack (expected 2, go ...

谢了
页: [1]
查看完整版本: 29讲:小甲鱼鱼小客服的split问题