鱼C论坛

 找回密码
 立即注册
查看: 761|回复: 11

[已解决]29讲:小甲鱼鱼小客服的split问题

[复制链接]
发表于 2020-4-4 15:57:16 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
代码如下:
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)
什么意思,看着视频敲的啊!求解!
最佳答案
2020-4-4 16:15:41
if判断不匹配,切片是几个右边就需要写几个等号:
if each_line[:6] != '======':
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-4 15:58:42 | 显示全部楼层
本帖最后由 zltzlt 于 2020-4-4 16:00 编辑

你的文件内容是什么?

close() 拼错了:

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


f.colse()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 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)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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 ...

文件没有问题?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

使用道具 举报

 楼主| 发表于 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()   
这个就可以运行。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-4 16:06:50 | 显示全部楼层
说明文件没问题
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-4 16:15:41 | 显示全部楼层    本楼为最佳答案   
if判断不匹配,切片是几个右边就需要写几个等号:
if each_line[:6] != '======':
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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个'=',所以分割行没有被排除而进入了下面的循环,导致了以上错误。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-4 16:16:15 From FishC Mobile | 显示全部楼层
ValueError: not enough values to unpack 这个错误应该是参数不正确,你文件使用的冒号和代码中的冒号同时英文标点,或者同是中文标点吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-4 16:29:22 | 显示全部楼层
谢谢8楼,9楼。终于明白了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 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 ...

谢了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-25 23:40

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表