python文件操作。

一、普通文本文件

with open() as f:用法

1. 常见用法:

1
2
3
4
5
6
with open(r'filename.txt') as f:
for l in f:
l = json.loads(l) #文件的读操作

with open('Hello.txt', 'w') as f:
f.write('hello world') #文件的写操作

2. 先关参数:

  • r: 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式
  • rb: 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
  • r+: 打开一个文件用于读写。文件指针将会放在文件的开头。
  • rb+:以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
  • w: 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
  • wb: 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
  • w+: 打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
  • wb+:以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
  • a: 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
  • ab: 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
  • a+: 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
  • ab+:以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

3. f的方法属性:

1
2
3
4
5
6
7
8
9
10
11
12
file.read([size])   #将文件数据作为字符串返回,可选参数size控制读取的字节数
file.readlines([size]) #返回文件中行内容的列表,size参数可选
file.write(str) #将字符串写入文件
file.writelines(strings) #将字符串序列写入文件
file.close() #关闭文件
file.closed #表示文件已经被关闭,否则为False

file.mode #Access文件打开时使用的访问模式
file.encoding #文件所使用的编码
file.name #文件名
file.newlines #未读取到行分隔符时为None,只有一种行分隔符时为一个字符串,当文件有多种类型的行结束符时,则为一个包含所有当前所遇到的行结束的列表
file.softspace #为0表示在输出一数据后,要加上一个空格符,1表示不加。这个属性一般程序员用不着,由程序内部使用

二、json文件

1. 写入

1
2
3
4
import json

with open('jsonfile.json','w') as f:
json.dump(data, f, indent=4)

2. 读取

1
2
3
4
import json

with open('jsonfile.json','w') as f:
data = json.load(f)

三、csv文件

1. 写入

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
import codecs
import csv

with codecs.open('accountFeature.csv','w','utf-8') as csvfile:
writer = csv.writer(csvfile)
#写入csv的字段,需要的继续后面添加
writer.writerow(['addr',
'bal',
'totalGet',
'totalSend',
'pr',
'maxSend',
'avgFee'
])
#writer.writerow(['userId','group','batch','testId'])
for addr in orderAddr:
writer.writerows([[addr,
feature[addr]['bal'],
feature[addr]['totalGet'],
feature[addr]['totalSend'],
feature[addr]['pr'],
feature[addr]['maxSend'],
feature[addr]['avgFee']
]])

2. 读取

1
2
3
4
5
6
import codecs
import csv

with codecs.open(file_name+'.csv','r','utf-8') as csvfile:
reader = csv.reader(csvfile)
result = list(reader)