今天来学习python中的文件操作这是很关键的,
这次先学习文件的读写,需要注意的是文件的权限的问题。
总结如下最常用的权限:
权限 | 备注 |
---|---|
r | 打开只读文件,该文件必须存在。 |
w | 打开只写文件,若文件存在则文件长度清为0, 即该文件内容会消失。若文件不存在则建立该文件。 |
r+ | 打开可读写的文件,该文件必须存在。 |
w+ | 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。 |
a | 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。 |
a+ | 以附加方式打开可读写的文件。 若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 |
总结下来有+的均可以读写。
只使用权限w写入的时候每一行会产生空行。
解决方法: 使用权限wb写入的时候不会产生空行。
你们也可以参考廖雪峰大神的python教学快速入门。
代码块
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Author : SundayCoder-俊勇
# @File : filelearn.py
# 今天我们来学习一下python中文件的操作。
# 很多机器学习需要读入csv文件
# 所以文件的操作是机器学习必须学会的一个技能
# (1)文件的打开和关闭[不标准的写法]
f=open('hello.txt','r')
print f.read()
f.close()
# 文件的操作的最后一步必须是关闭文件。
# 因为read()函数是一次性输出文件的所有数据
# 所以输出结果为:
# hello wolrd
# 你好啊
# (2)文件打开过程中会有错误,所以可以使用try-finally来处理错误
# 文件的打开与关闭的标准写法。
try:
f = open('hello.txt', 'r')
print f.read()
finally:
if f:#如果f存在则关闭
f.close()
# (3)文件的打开和关闭每次都这么写实在太繁琐,
# 所以,Python引入了with语句来自动帮我们调用close()方法:
with open('hello.txt', 'r') as f:
print f.read()
# 注:第三种是最常用的一种方法,必须要掌握的方法。
# (4)如果打开的文件不存在则会报错:
# with open('hello1.txt', 'r') as f:
# print f.read()
# 报错的内容为:IOError: [Errno 2] No such file or directory: 'hello1.txt'
# 报错会提示你打开的文件不存在。
# (5)读取文件的方法的比较。
# 调用read()会一次性读取文件的全部内容,
# 如果文件有10G,内存就爆了,所以,
# 要保险起见,可以反复调用read(size)方法,
# 每次最多读取size个字节的内容。
# 另外,调用readline()可以每次读取一行内容,
# 调用readlines()一次读取所有内容并按行返回list。
# 因此,要根据需要决定怎么调用。
# 如果文件很小,read()一次性读取最方便;
# 如果不能确定文件大小,反复调用read(size)比较保险;
# 如果是配置文件,调用readlines()最方便:
# 例如:
with open('hello.txt', 'r') as f:
print f.read(2)
# 输出的结果为:he
# 注:英文字母一个占一个字节,中文一个占两个字节。
# 读取文件最最常用的一种方法。
with open('hello.txt', 'r') as f:
for line in f.readlines():#每次读取一行
print(line.strip()) # 把每一个行的末尾的'\n'删掉
# 输出的结果:
# hello wolrd
# 你好啊
# (8)文件的写操作。
# fp.write(str) #把str写到文件中,
# write()并不会在str后加上一个换行符
# fp.writelines(seq) #把seq的内容全部写到文件中
# (多行一次性写入)这个函数也只是忠实地写入,不会在每行后面加上任何东西。
with open('hello1.txt', 'w') as f:
f.write("this is new content")
# 写入之后重新查看文档内容
with open('hello1.txt', 'r') as f:
for line in f.readlines(): # 每次读取一行
print(line.strip()) # 把每一个行的末尾的'\n'删掉
# 输出的结果为:this is new content
# 说明原来的内容已经被覆盖掉了,这与文章的权限有关。
#文章的权限总结如下:
# (1)r 打开只读文件,该文件必须存在。
# (2)r+ 打开可读写的文件,该文件必须存在。
# (3)w 打开只写文件,若文件存在则文件长度清为0,
# 即该文件内容会消失。若文件不存在则建立该文件。
# (4)w+ 打开可读写文件,若文件存在则文件长度清为零,
# 即该文件内容会消失。若文件不存在则建立该文件。
# (5)a 以附加的方式打开只写文件。若文件不存在,
# 则会建立该文件,如果文件存在,写入的数据会被加到文件尾,
# 即文件原先的内容会被保留。
# (6) a+ 以附加方式打开可读写的文件。
# 若文件不存在,则会建立该文件,
# 如果文件存在,写入的数据会被加到文件尾后,
# 即文件原先的内容会被保留。
加油一起学习,更新完毕