Python(文件读取、序列化反序列化)

借鉴菜鸟教程

一、读取

open() 将会返回一个 file 对象,基本语法格式如下:

open(filename, mode)(filename, mode)
  • filename:包含了你要访问的文件名称的字符串值。
  • mode:决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。

不同模式打开文件的完全列表:

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

  r+与w+的区别:

    r+:如果读写的文件存在。会在后面追加,不存在系统会报错。

    w+:读写的文件不存在会创建新的文件,如果存在会直接覆盖原文件。

二、方法    

        f.read()

          为了读取一个文件的内容,调用 f.read(size), 这将读取一定数目的数据, 然后作为字符串或字节对象返回。

扫描二维码关注公众号,回复: 2553552 查看本文章

                size 是一个可选的数字类型的参数。 当 size 被忽略了或者为负, 那么该文件的所有内容都将被读取并且返回。

                readline(),readlines() 

            

        f.write()

                f.write(string) 将 string 写入到文件中, 然后返回写入的字符数。

            

         f.tell()

            f.tell() 返回文件对象当前所处的位置, 它是从文件开头开始算起的字节数。

        f.seek()

        如果要改变文件当前的位置, 可以使用 f.seek(offset, from_what) 函数。

        from_what 的值, 如果是 0 表示开头, 如果是 1 表示当前位置, 2 表示文件的结尾,例如:

  • seek(x,0) : 从起始位置即文件首行首字符开始移动 x 个字符
  • seek(x,1) : 表示从当前位置往后移动x个字符
  • seek(-x,2):表示从文件的结尾往前移动x个字符        

    f.close()

    在文本文件中 (那些打开文件的模式下没有 b 的), 只会相对于文件起始位置进行定位。

    当你处理完一个文件后, 调用 f.close() 来关闭文件并释放系统的资源,如果尝试再调用该文件,则会抛出异常。

with open('too.txt','r') as f:
    print(f.readlines(4))
from urllib import request
request=request.urlopen('http://www.baidu.com/')
f=open('baidu.txt','w')
page=f.write(str(request.read()))
f.close()

二、序列化、反序列化

        

        python的pickle模块实现了基本的数据序列和反序列化。

        通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储。

        通过pickle模块的反序列化操作,我们能够从文件中创建上一次程序保存的对象。

基本接口:        

pickle.dump(obj, file, [,protocol]).dump(obj, file, [,protocol])
import pickle
dic={'a':[1,2,3],'b':(3,5,7)}
f=open('xi.pkl','wb')
pickle.dump(dic,f)
f.close()
p=open('xi.txt','rb')
di=pickle.load(p)
print(di)

猜你喜欢

转载自blog.csdn.net/qq_42351920/article/details/81020568