刚刚用open(fileName)来打开txt格式的文件,总是出现错误,总是找不到文件读取的内容,后来才发现是open()在使用过程中自动关闭了。这里介绍另种方法解决这个问题。
第一种方法。
with open(fileName) as file_object:
content=file_object.read()
其实就是将文件对象保存给file_object,然后将文件内容读取保存给content,这种方法Python会在程序不需要调用文件时自动关闭文件,不需要我们去调用close()来关闭文件。
当我们过早的调用close()时,需要使用文件时就会出现文件无法调用的情况,所以不推荐自己使用open(),close()方式来打开文件。
第二种方法。
将文件内容保存到列表里面,这样就算文件关闭了,我们直接访问列表里面保存的文件内容就可以了。
with open(fileName) as file_name: lines=file_name.readlines() for line in lines: print(line.rstrip())
用readlines()来将内容保存到列表里,并且通过逐行访问列表内容来获得文件内容。
例子:
1 def loadData(fileName): 2 dataMat=[];labelMat=[] 3 fr=open(fileName) 4 dataContent=fr.readlines() 5 #用一个列表把文件内容装起来,否则用open打开文件后会自动关闭,在后面直接访问fr时文件已经关闭,获取不到文件了, 6 # 也可以用with open (fileName) as fr:这种操作会根据文件使用情况来自动关闭 7 featNum=len(dataContent[0].strip().split(' '))-1#数据的属性数量 8 print(featNum) 9 for line in dataContent: 10 lineArr = [] 11 curLine=line.strip().split(' ')#对每行数据分割成与属性数相等的数据 12 for i in range(featNum): 13 lineArr.append(float(curLine[i])) 14 dataMat.append(lineArr) 15 labelMat.append(float(curLine[-1])) 16 return dataMat,labelMat
如果我们去掉dataContent=fr.readlines()这一行内容,而一直用fr来不断的调用文件,会发现无法掉出数据,因为文件在第一次使用后就关闭了,后面的文件便无法调用出来。