鱼C论坛

 找回密码
 立即注册
查看: 2166|回复: 20

[已解决]question

[复制链接]
发表于 2020-9-19 10:23:54 | 显示全部楼层 |阅读模式

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

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

x
  1. f = open('D:/python-3.8.5/文档1.txt')
  2. me=[]
  3. he=[]
  4. count=1

  5. for eachline in f:
  6.     if eachline[:6] != '=====':
  7.         (role, linespoken)=eachline.split(':',2)
  8.         if role=='我说':
  9.             me.append(linespoken)
  10.         if role=='她说':
  11.             he.append(linespoken)
  12.         #进行字符串的分割
  13.     else:
  14.         file_name_me = 'me_'+str(count)+'.txt'
  15.         file_name_he = 'he_'+str(count)+'.txt'


  16.         me_file=open(file_name_me,'w')
  17.         he_file=open(file_name_he,'w')


  18.         me_file.writelines(me)
  19.         he_file.writelines(he)
  20.         #文件的分别保存
  21.         me_file.close()
  22.         he_file.close()


  23.         me=[]
  24.         he=[]
  25.         count+=1


  26. f.close()
复制代码

#文本是下面这个
我说:打开一个文件我们使用 函数,通过设置文件的打开模式,
他说:上啊手工业商业!!!!
我说:一二三四五
他说:上山打老虎
我说:充钱有座山%%%
他说:山上有座庙***
==========
我说:通过设置文件的打开模式,
他说:上啊手工业商业!!!!
我说:一二三四五
他说:上山打老虎
我说:充钱有座山%%%
他说:山上有座庙***
==========
我说:打开一个文件我们使用 函数
他说:上啊手工业商业!!!!
我说:一二三四五
他说:上山打老虎
我说:充钱有座山%%%
他说:山上有座庙***



#为什么会报错呀?????
最佳答案
2020-9-19 12:16:37

这里的  if eachline[:6] != '=====':   少了一个等号,你可以增加一个,或者将切片 [:6] 改成 [:5]

还有你 split 的切割符号应该改成中文的冒号,而且只需要切割一次即可,讲 2 改成 1

  1. f = open('D:/python-3.8.5/文档1.txt')
  2. me=[]
  3. he=[]
  4. count=1

  5. for eachline in f:
  6.     if eachline[:6] != '======':
  7.         (role, linespoken)=eachline.split(':',1)
  8.         if role=='我说':
  9.             me.append(linespoken)
  10.         if role=='她说':
  11.             he.append(linespoken)
  12.         #进行字符串的分割
  13.     else:
  14.         file_name_me = 'me_'+str(count)+'.txt'
  15.         file_name_he = 'he_'+str(count)+'.txt'


  16.         me_file=open(file_name_me,'w')
  17.         he_file=open(file_name_he,'w')


  18.         me_file.writelines(me)
  19.         he_file.writelines(he)
  20.         #文件的分别保存
  21.         me_file.close()
  22.         he_file.close()


  23.         me=[]
  24.         he=[]
  25.         count+=1


  26. f.close()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-9-19 10:35:11 | 显示全部楼层
所以报错是什么
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 10:49:08 | 显示全部楼层
昨非 发表于 2020-9-19 10:35
所以报错是什么

ValueError: not enough values to unpack (expected 2, got 1)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-19 11:07:56 | 显示全部楼层
本帖最后由 sunrise085 于 2020-9-19 11:10 编辑
3216207773 发表于 2020-9-19 10:49
ValueError: not enough values to unpack (expected 2, got 1)


问题一、
你的文件中冒号都是中文冒号,在程序第8行切分的时候用的是英文冒号。这俩地方改一致就可以了
再者,文件中不要有空行,尤其是末尾,容易被忽略

问题二、
还有,第7行不等号前面是截取了前六个字符,但是不等号后面的字符串中只有五个等号
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 11:20:46 | 显示全部楼层
sunrise085 发表于 2020-9-19 11:07
问题一、
你的文件中冒号都是中文冒号,在程序第8行切分的时候用的是英文冒号。这俩地方改一致就可以 ...

应该是空行的问题,怎么去除呢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-19 11:28:06 | 显示全部楼层
3216207773 发表于 2020-9-19 11:20
应该是空行的问题,怎么去除呢

。。。。。
删除文件中的空行就可以了啊
。。。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-19 11:47:45 | 显示全部楼层
你写eachline[0:6],后面只有5个=
  1. f = open('1.txt',encoding='utf-8')
  2. me=[]
  3. he=[]
  4. count=1

  5. for eachline in f:
  6.     if eachline[:5] != '=====':
  7.         role, linespoken=eachline.split(':')
  8.         if role=='我说':
  9.             me.append(linespoken)
  10.         if role=='他说':
  11.             he.append(linespoken)
  12.         #进行字符串的分割
  13.     else:
  14.         file_name_me = 'me_'+str(count)+'.txt'
  15.         file_name_he = 'he_'+str(count)+'.txt'


  16.         me_file=open(file_name_me,'w')
  17.         he_file=open(file_name_he,'w')


  18.         me_file.writelines(me)
  19.         he_file.writelines(he)
  20.         #文件的分别保存
  21.         me_file.close()
  22.         he_file.close()


  23.         me=[]
  24.         he=[]
  25.         count+=1

  26.     file_name_me = 'me_' + str(count) + '.txt'
  27.     file_name_he = 'he_' + str(count) + '.txt'

  28.     me_file = open(file_name_me, 'w')
  29.     he_file = open(file_name_he, 'w')

  30.     me_file.writelines(me)
  31.     he_file.writelines(he)
  32.     # 文件的分别保存
  33.     me_file.close()
  34.     he_file.close()


  35. f.close()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-19 12:16:37 | 显示全部楼层    本楼为最佳答案   

这里的  if eachline[:6] != '=====':   少了一个等号,你可以增加一个,或者将切片 [:6] 改成 [:5]

还有你 split 的切割符号应该改成中文的冒号,而且只需要切割一次即可,讲 2 改成 1

  1. f = open('D:/python-3.8.5/文档1.txt')
  2. me=[]
  3. he=[]
  4. count=1

  5. for eachline in f:
  6.     if eachline[:6] != '======':
  7.         (role, linespoken)=eachline.split(':',1)
  8.         if role=='我说':
  9.             me.append(linespoken)
  10.         if role=='她说':
  11.             he.append(linespoken)
  12.         #进行字符串的分割
  13.     else:
  14.         file_name_me = 'me_'+str(count)+'.txt'
  15.         file_name_he = 'he_'+str(count)+'.txt'


  16.         me_file=open(file_name_me,'w')
  17.         he_file=open(file_name_he,'w')


  18.         me_file.writelines(me)
  19.         he_file.writelines(he)
  20.         #文件的分别保存
  21.         me_file.close()
  22.         he_file.close()


  23.         me=[]
  24.         he=[]
  25.         count+=1


  26. f.close()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 12:45:59 | 显示全部楼层
sunrise085 发表于 2020-9-19 11:28
。。。。。
删除文件中的空行就可以了啊
。。。。。

我是不是有点傻,哈哈哈哈
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 13:04:57 | 显示全部楼层
Twilight6 发表于 2020-9-19 12:16
这里的  if eachline[:6] != '=====':   少了一个等号,你可以增加一个,或者将切片 [:6] 改成 [:5]

...
  1. f = open('D:/python-3.8.5/文档1.txt')
  2. me=[]
  3. he=[]
  4. count=1

  5. for eachline in f:
  6.     if eachline[:6] != '======':
  7.         (role, linespoken)=eachline.split(':',1)
  8.         if role=='我说':
  9.             me.append(linespoken)
  10.         if role=='她说':
  11.             he.append(linespoken)
  12.         #进行字符串的分割
  13.     else:
  14.         file_name_me = 'me_'+str(count)+'.txt'
  15.         file_name_he = 'he_'+str(count)+'.txt'


  16.         me_file=open(file_name_me,'w')
  17.         he_file=open(file_name_he,'w')


  18.         me_file.writelines(me)
  19.         he_file.writelines(he)
  20.         #文件的分别保存
  21.         me_file.close()
  22.         he_file.close()


  23.         me=[]
  24.         he=[]
  25.         count+=1


  26. f.close()
复制代码

#改完之后,为什么会显示split里面的那个1为invalid character in identifier?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-19 13:09:29 | 显示全部楼层
3216207773 发表于 2020-9-19 13:04
#改完之后,为什么会显示split里面的那个1为invalid character in identifier?




发报错 完整信息 ,而且你代码的冒号没改过来还是英文的,但是你给的文本是中文冒号

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 13:18:23 | 显示全部楼层
Twilight6 发表于 2020-9-19 13:09
发报错 完整信息 ,而且你代码的冒号没改过来还是英文的,但是你给的文本是中文冒号

#冒号改过来了
我说:打开一个文件我们使用函数,通过设置文件的打开模式,
他说:上啊手工业商业!!!!
我说:一二三四五
他说:上山打老虎
我说:充钱有座山%%%
他说:山上有座庙***
==========
我说:通过设置文件的打开模式,
他说:上啊手工业商业!!!!
我说:一二三四五
他说:上山打老虎
我说:充钱有座山%%%
他说:山上有座庙***
==========
我说:打开一个文件我们使用 函数
他说:上啊手工业商业!!!!
我说:一二三四五
他说:上山打老虎
我说:充钱有座山%%%
他说:山上有座庙***
#这个是文档
  1. f = open('D:/python-3.8.5/文档1.txt')
  2. me=[]
  3. he=[]
  4. count=1

  5. for eachline in f:
  6.     if eachline[:6] != '======':
  7.         (role, linespoken)=eachline.split(':',2)
  8.         if role=='我说':
  9.             me.append(linespoken)
  10.         if role=='她说':
  11.             he.append(linespoken)
  12.         #进行字符串的分割
  13.     else:
  14.         file_name_me = 'me_'+str(count)+'.txt'
  15.         file_name_he = 'he_'+str(count)+'.txt'


  16.         me_file=open(file_name_me,'w')
  17.         he_file=open(file_name_he,'w')


  18.         me_file.writelines(me)
  19.         he_file.writelines(he)
  20.         #文件的分别保存
  21.         me_file.close()
  22.         he_file.close()


  23.         me=[]
  24.         he=[]
  25.         count+=1


  26. f.close()
复制代码

#这个是代码,报错的是弹出小窗口显示invalid character in identifier
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-19 13:23:40 | 显示全部楼层
3216207773 发表于 2020-9-19 13:18
#冒号改过来了
我说:打开一个文件我们使用函数,通过设置文件的打开模式,
他说:上啊手工业商业!!! ...

第八行 最后那个 2 前面的逗号写成中文逗号了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 13:27:00 | 显示全部楼层
sunrise085 发表于 2020-9-19 13:23
第八行 最后那个 2 前面的逗号写成中文逗号了

额,对对对
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 13:28:42 | 显示全部楼层
sunrise085 发表于 2020-9-19 13:23
第八行 最后那个 2 前面的逗号写成中文逗号了

为什么he_.txt都是空的没有内容?但me_.txt有内容
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-19 13:28:56 | 显示全部楼层

以后发帖子,请不要这么懒。
给帖子起个名字。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 13:33:09 | 显示全部楼层
sunrise085 发表于 2020-9-19 13:28
以后发帖子,请不要这么懒。
给帖子起个名字。。。

嗯,像这个叫啥名字?he_1.txt和he_2.txt都是空的为什么
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-19 13:38:52 | 显示全部楼层
3216207773 发表于 2020-9-19 13:33
嗯,像这个叫啥名字?he_1.txt和he_2.txt都是空的为什么

代码中是“她说”
文件中是“他说”
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 13:41:57 | 显示全部楼层
sunrise085 发表于 2020-9-19 13:38
代码中是“她说”
文件中是“他说”

额,把split(':',1)1和2都可以成功,改成0就报错Traceback (most recent call last):
  File "D:\python-3.8.5\test.py", line 8, in <module>
    (role, linespoken)=eachline.split(':',0)
ValueError: not enough values to unpack (expected 2, got 1)
求教
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-19 13:50:14 | 显示全部楼层
sunrise085 发表于 2020-9-19 13:38
代码中是“她说”
文件中是“他说”

还有就是为什么要用str(count)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-27 09:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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