文件操作和序列化
文件操作
通过内置的open()函数打开一个文件对象。
格式:fd=open('filename')
以不同模式打开一个文件对象:
模式 | 描述 |
---|---|
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。 |
r+ | 打开一个文件用于读写。文件指针将会放在文件的开头。 |
rb+ | 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。 |
w | 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。 |
w+ | 打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb+ | 以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
ab | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
a+ | 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 |
ab+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |
示例:
[xxoo:/tmp]$ cat tmpfile
hello
world
只读方式:
#!/usr/bin/env python
file=open('tmpfile','r')
print(file.read().strip())
file.close() #关闭文件操作
写方式:
#!/usr/bin/env python
file=open('tmpfile','w')
file.write("12345\n")
file.close()
再次查看tmpfile 输出:12345
方法:
file.close() #关闭文件操作
file.flush() #刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件 (可以通过time.sleep()函数 观察写入的数据 磁盘刷新情况)
file.fileno() #返回一个整型的文件描述符
file.isatty() #如果文件连接到一个终端设备返回 True,否则返回 False
file.read([size]) #从文件读取指定的字节数,未给定size或size为负数时读取所有数据
file.readline() #读取整行
file.readlines() #读取所有行并返回列表
file.seek(offset[,whence]) #设置当前文件位置
file.tell() #返回文件当前位置
file.truncate([size]) #截取文件,截取的字节通过size指定,从文件开始位置截取
file.write(str) #将str写入到文件中
file.writelines(sequence) #向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。
以上对文件操作并不推荐,写数据时存在数据丢失情况
推荐使用: with open(filename,'rw') as fd:
fd.write(str)
序列化
通过将对象序列化可以将其存储在变量或者文件中,可以保存当时对象的状态,实现其生命周期的延长。并且需要时可以再次将这个对象读取出来。
json.dumps()
用于将dict类型的数据转成str,因为如果直接将dict类型的数据写入json文件中会发生报错,因此在将数据写入时需要用到该函数。
#!/usr/bin/env python import json name_emb = {'name':'python','age':'20'} jsObj = json.dumps(name_emb) print(name_emb) print(jsObj) print(type(name_emb)) print(type(jsObj)) 输出: {'name': 'python', 'age': '20'} {"name": "python", "age": "20"} <class 'dict'> <class 'str'>
json.loads()
用于将str类型的数据转成dict。
#!/usr/bin/env python import json name_emb = {'name':'python','age':'20'} jsDumps = json.dumps(name_emb) jsLoads = json.loads(jsDumps) print(name_emb) print(jsDumps) print(jsLoads) print(type(name_emb)) print(type(jsDumps)) print(type(jsLoads)) 输出: {'age': '20', 'name': 'python'} {"age": "20", "name": "python"} {'age': '20', 'name': 'python'} <class 'dict'> <class 'str'> <class 'dict'>
json.dump()
用于将dict类型的数据转成str,并写入到json文件中。
#!/usr/bin/env python
import json
name_emb = {'name':'python','age':'20'}
emb_filename = ('emb_json.json')
f=open(emb_filename, "w")
json.dump(name_emb,f)
cat emb_json.json 输出:{"name": "python", "age": "20"}
json.load()
用于从json文件中读取数据。
#!/usr/bin/env python import json f=open('emb_json.json','r') data=json.load(f) print (type(data)) for k,v in data.items(): print (k,v) 输出: <class 'dict'> name python age 20
赠人玫瑰,手有余香,如果我的文章有幸能够帮到你,麻烦帮忙点下右下角的推荐,谢谢!
作者: imcati
出处: https://www.cnblogs.com/imcati/>
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出, 原文链接