文件操作和序列化

文件操作

通过内置的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

 

posted @ 2018-08-26 16:34  imcati  阅读(162)  评论(0编辑  收藏  举报