这里记录的是最基本的TXT文件的读写操作
open() close() with open(...) as ...
文件对象提供了三个“读”方法: .read()、.readline() 和 .readlines()。每种方法可以接受一个变量以限制每次读取的数据量,但它们通常不使用变量。
read()方法:
可以一次性读取全部内容,Python把内容读到内存,用一个str对象返回
但若文件过大,内存就爆了,所有可以反复调用read(size)方法,每次最多读取size个字节的内容。
.read() 生成文件内容最直接的字符串表示,但对于连续的面向行的处理,它却是不必要的,并且如果文件大于可用内存,则不可能实现这种处理
file_object = "E:/abc"
f = open(file_object,'r')
print(f.read()) #输出文件内容
f.close()
注意open之后一定要close。但由于文件读写可能产生IOError,为了保证是否出错都能正确关闭文件,加上try
file_object = "E:/abc"
try:
f = open(file_object,'r')
print(f.read()) #输出文件内容
finally:
f.close()
python 简化了写法,一般用with open() as ...这样就不用自己close了,会自动给close
with open(file_opject,'r') as f:
f.read()
readline() :
每次读取一行内容
.readline()每次只读取一行,通常比 .readlines()慢得多。仅当没有足够内存可以一次读取整个文件时,才应该使用.readline()。
#读一行
with open(file, 'r') as f:
K = int(f.readline())
#一行一行读完
result = list()
for line in open(file):
line = f.readline()
print line
result.append(line)
print result
f.close()
readlines():
一次读取所有内容并按行返回list
readlines()自动将文件内容分析成一个行的列表,该列表可以由 Python 的 for... in ... 结构进行处理
with open(file, 'r') as f:
K = int(f.readline())
# print(K)
# 获得每行数值,以.作为分隔符分别存储
for line in f.readlines():
line = line.strip().split('.')
content.append(line)
先读取一行获得某些需要的值,之后一次性读取,按行返回会带上换行符需要用.strip()去除(这里我是拿自己有用到的程序截取了部分)
附上读写操作的表格
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。 |
r+ | 打开一个文件用于读写。文件指针将会放在文件的开头。 |
rb+ | 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。 |
w | 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
w+ | 打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
wb+ | 以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
ab | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
a+ | 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 |
ab+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |