打算写一个读取文本文件的方法,readTextFile()
以下是我的代码:
#encoding=utf-8
import os
def readTextFile():
fname=input("请输入文件名:")
try:
fobj=open(fname,'r')
except (IOError,e):
print('文件打开错误:',e)
else:
for eachLine in fobj:
print(eachLine,)
fobj.close()
readTextFile()然后就报了UnicodeDecodeError: 'gbk' codec can't decode byte 0x88 in position 20: illegal multibyte sequence的错误
于是经过查询资料,就在open内置函数里面加了encoding=‘UTF-8’,open()函数中fname为文件名、r为reading,encoding=utf-8,我理解的意思是将fname以utf-8字符形式打开只读
然后代码变为如下:
#encoding=utf-8
import os
def readTextFile():
fname=input("请输入文件名:")
try:
fobj=open(fname,'r',encoding='UTF-8')
except (IOError,e):
print('文件打开错误:',e)
else:
for eachLine in fobj:
print(eachLine,)
fobj.close()
readTextFile()但是依然报了另一个错误:
ValueError: I/O operation on closed file.
经过检查发现是我的fobj.close()的缩进有问题,被放到了for循环下面故而报错,于是将fobj.close()移出for循环
最终代码为:
#encoding=utf-8
import os
def readTextFile():
fname=input("请输入文件名:")
try:
fobj=open(fname,'r',encoding='UTF-8')
except (IOError,e):
print('文件打开错误:',e)
else:
for eachLine in fobj:
print(eachLine,)
fobj.close()
readTextFile()
本文记录了作者在实现readTextFile()方法过程中遇到的问题及解决过程。通过在open()函数中添加encoding='UTF-8'参数来确保以UTF-8编码读取文本文件。由于缩进错误,导致ValueError: I/O operation on closed file.,修正缩进后,问题得到解决。最终代码顺利读取并处理文件。

2247

被折叠的 条评论
为什么被折叠?



