鱼C论坛

 找回密码
 立即注册
查看: 1856|回复: 15

[已解决]萌新求助:想把一个文件中的每句话作为一行 但是敲了代码运行出错

[复制链接]
发表于 2020-12-31 21:14:48 | 显示全部楼层 |阅读模式

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

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

x
f = open(r"C:\Users\pp980\Desktop\lala.txt")
b = []

for i in f:
    i = i.replace("。" , '\n')
    b.append(i)
    x = 'boy' + '.txt'
    y = open(x , 'w')
    y.writelines(b)

y.colse()
f.close()
#求各位大佬不吝赐教
最佳答案
2020-12-31 21:37:00
pretty22 发表于 2020-12-31 21:23
还是 这个:
Traceback (most recent call last):
  File "C:%users\pp980\Desktop\分隔字符.py", line ...

编码问题,改成这样:
f = open(r"C:\Users\pp980\Desktop\lala.txt", encoding = "utf-8")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-12-31 21:18:41 | 显示全部楼层
本帖最后由 Daniel_Zhang 于 2020-12-31 21:21 编辑

y.colse()是啥

下次麻烦一起发一下错误信息

建议使用with open,这样就不需要关闭文件了,会自动保存

如果觉得答案对你有帮助,请设置为最佳答案。找 bug 不易,另外预祝新年快乐~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-31 21:20:12 | 显示全部楼层
Daniel_Zhang 发表于 2020-12-31 21:18
y.colse()是啥

下次麻烦一起发一下错误信息

就是close 刚刚打错了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-31 21:21:43 | 显示全部楼层
pretty22 发表于 2020-12-31 21:20
就是close 刚刚打错了

那修改了以后还有 bug 吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-31 21:23:47 | 显示全部楼层
Daniel_Zhang 发表于 2020-12-31 21:21
那修改了以后还有 bug 吗

还是 这个:
Traceback (most recent call last):
  File "C:\Users\pp980\Desktop\分隔字符.py", line 4, in <module>
    for i in f:
UnicodeDecodeError: 'gbk' codec can't decode byte 0xaf in position 32: illegal multibyte sequence
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-31 21:29:23 | 显示全部楼层
本帖最后由 Daniel_Zhang 于 2020-12-31 21:31 编辑

你试试看这个
f = open(r"C:\Users\pp980\Desktop\lala.txt", 'r')

以只读的形式打开你的 txt 文件夹,读取里面的内容
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-31 21:37:00 | 显示全部楼层    本楼为最佳答案   
pretty22 发表于 2020-12-31 21:23
还是 这个:
Traceback (most recent call last):
  File "C:%users\pp980\Desktop\分隔字符.py", line ...

编码问题,改成这样:
f = open(r"C:\Users\pp980\Desktop\lala.txt", encoding = "utf-8")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-31 21:37:45 | 显示全部楼层
Daniel_Zhang 发表于 2020-12-31 21:29
你试试看这个
f = open(r"C:%users\pp980\Desktop\lala.txt", 'r')

只读模式是open的默认模式,不用设置的
问题出在了编码上
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-31 21:39:46 | 显示全部楼层
qiuyouzhi 发表于 2020-12-31 21:37
只读模式是open的默认模式,不用设置的
问题出在了编码上


这个我也觉得不太可能回事这个问题,这就有点......主要是我把他的代码拷下来了,改成了自己的文件路径,就跑出来了

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

使用道具 举报

发表于 2020-12-31 21:40:40 From FishC Mobile | 显示全部楼层
在循环中不停地打开文件,应该不是你想要的
f = open(r"C:\Users\pp980\Desktop\lala.txt", encoding='utf-8')
b = []

for i in f:
    i = i.replace("。" , '\n')
    b.append(i)
x = 'boy' + '.txt'
y = open(x , 'w')
y.writelines(b)

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

使用道具 举报

发表于 2020-12-31 21:40:41 | 显示全部楼层
Daniel_Zhang 发表于 2020-12-31 21:39
这个我也觉得不太可能回事这个问题,这就有点......主要是我把他的代码拷下来了,改成了自己的文件路径 ...

因为你自己的文件编码和他的那个不一样
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-31 21:41:18 | 显示全部楼层
qiuyouzhi 发表于 2020-12-31 21:40
因为你自己的文件编码和他的那个不一样

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

使用道具 举报

 楼主| 发表于 2020-12-31 21:48:40 | 显示全部楼层
qiuyouzhi 发表于 2020-12-31 21:37
编码问题,改成这样:

大佬 跑出来了  
这个encoding = "utf-8" 是什么意思啊
还请不吝赐教
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-31 22:04:05 | 显示全部楼层
pretty22 发表于 2020-12-31 21:48
大佬 跑出来了  
这个encoding = "utf-8" 是什么意思啊
还请不吝赐教

把编码改为utf-8
简单比喻一下,就是用英文(utf-8)读文件,而不是用中文(gbk)读
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-31 22:20:53 | 显示全部楼层
qiuyouzhi 发表于 2020-12-31 22:04
把编码改为utf-8
简单比喻一下,就是用英文(utf-8)读文件,而不是用中文(gbk)读

哦哦 懂了 就是读取的方式不一样是吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-31 22:27:31 From FishC Mobile | 显示全部楼层
pretty22 发表于 2020-12-31 22:20
哦哦 懂了 就是读取的方式不一样是吧

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-16 22:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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