自学Python一周,尝试用Python读取自己编写的txt文件,文件读取时总遇到些小问题,以下是个人的总结
Python的文件分两种:文本文件及二进制文件。
文本文件:以纯ASCII编码
二进制文件:音频,视频,图像文件等。
文件的读取包括:文件打开,文件操作,文件关闭等
文件的打开模式,读取模式有以下几种:
以下是一段简单的文件读取代码:
import codecs#库导入,方便文件读取,解码
def getData(lst):
#解码,data.txt编码格式为utf-8
#编写txt时要注意编码格式的选择,有utf-8 without BOM 及utf-8格式,相应的解码格式为‘utf-8’,'utf-8-sig'
with codecs.open('data.txt','r','utf-8-sig') as infile:
line = infile.readline()
while line!='':
line = line.strip()#去除前后空格
lines = list(map(float,line.split(',')))#分割字符串,并转为list累型
lst.append(lines)
line = str(infile.readline())
print(lst)
infile.close()
#函数调用
getData()
data.txt
300,0,144,1,0,0
300,0,144,0,1,0
300,0,144,0,0,1
300,0,144,1,1,0
300,0,108,0,1,1
184,0, 72,1,0,1
184,0, 72,0,0,0
184,0, 72,0,0,0
184,0, 72,0,0,0
文件读取问题:
1. lines = list(map(float,line.split(',')))
ValueError: could not convert string to float: '\ufeff300'
解码格式不对应导致出错,参考编码与解码:
stackoverflow.com/questions/17912307/u-ufeff-in-python-string
2.编写txt文件时要注意编码格式的选择,文件读取时要进行相应的解码
3.ANSI编码格式时,无需解码
网友评论