附菜鸟教程OS及OS.path模块:http://www.runoob.com/python3/python3-os-file-methods.html
文件读写
python内置了读写文件的函数,用法与c兼容
打开文件
要以哪种模式打开一个文件对象,使用python内置的open()函数,传入文件名和标识符:
f = open('/user/test.txt' , 'r')
若文件不存在,open()函数会抛出IOError的错误,给出错误码和详细的信息告诉你文件不存在
open()函数
第一个参数为要打开的文件路径名
第二个参数描述文件如何使用的字符,‘r’ 为只读;‘w’ 用于写(如果存在同名文件则将被删除,如果该文件不存在,创建新文件),从头开始编辑文件,即原有的内容将会被删除;‘a’ 用于追加,如果文件已存在,文件指针将会放在文件末尾。也就是说,即原有的内容会被删除,如果文件不存在,创建新文件。
字符编码
接下来的open参数中加了encoding='utf-8',指定文件以utf-8方式读取,避免出现中文乱码,出现中文乱码时尝试修改读取方式的编码。原理略,不是搞开发的,以后慢慢查
文件对象的方法
f.read()
为了读取文件的内容,调用 f.read(size),这将读取一定数目的数据,然后作为字符串或字节对象返回。size是一个可选的数字类型的参数。当size被忽略或者为负,那么该文件的所有内容都将被读取并返回
f = open("/tmp/foo.txt", "r")
str = f.read()
print(str)
f.readlines(),该函数将返回该文件中包含的所有行,包括字符\n。
f.readline() 可以每次读取一行内容
#!/usr/bin/python3
# 打开一个文件
f = open("/tmp/foo.txt", "r")
str = f.readlines()
print(str)
# 关闭打开的文件
f.close()
f.write(string) 将string写入到文件中,然后返回写入的字符数。
#!/usr/bin/python3
# 打开一个文件
f = open("/tmp/foo.txt", "w")
num = f.write( "Python 是一个非常好的语言。" )
print(num)
# 关闭打开的文件
f.close()
f.close()当处理文件时,调用f.close()来关闭文件并释放系统的资源,如果尝试再调用该文件,则会抛出异常
#!/usr/bin/python3
# 打开一个文件
f = open("/tmp/foo.txt", "r")
str = f.readlines()
print(str)
# 关闭打开的文件
f.close()
实例(将内容输出到控制台)
readline方式读取文件
此方式每次只读取一行,经过实际测试,with方式读取依然每次读取一行,不会循环读取,它只是执行完它范围内的代码会自动调用close()函数,如果使用逐行读取的方式,依然需要循环控制读取,这样才能确保每行都能读取到控制台,读取速度较慢,节省内存
# f=open('./a.txt',encoding='utf-8')
# data1= f.readlines()
# print(data1)
with open('./a.txt',encoding='utf-8') as f:
data1 = f.readline()
while data1:
data1=f.readline()
print(data1)
read方式读取
此方式会一次读取所有文件内容,读取速度快,但是内存占用大
with open('./a.txt', encoding='utf-8') as f:
data1 = f.read()
print(data1)
readlines方式读取
可以一次读取多行,能提升速度,内存使用稍大,可根据情况调整一次读取的字节,参数为字节数
with open('./a.txt',encoding='utf-8') as f:
data1 = f.readlines(10)
print(data1)
for循环的方式读取
Python的for循环和其他语言不同,迭代。我理解就是把整个文章每一行看成一个对象输出(日后深究),注意这种方法,需要在for循环之前,定义一个变量接收open返回来的对象,以方便后边关闭文件对象并释放系统资源
f = open('./a.txt',encoding='utf-8')
for line in f:
print(line)
f.close()