Python3学习笔记 | 九、Python的类型与运算-文件

  • 2019 年 10 月 6 日
  • 筆記

一、文件简介

文件对象在Python里是可以作为OS(操作系统)上的文件的链接。 文件对象的使用方式与之前的字符串、列表等对象不同,它是对文件的输入、输出进行控制。 在Python里会用open函数(方法)来进行文件的控制。(也有其它方法可以进行文件的读取与写入)

二、文件的访问

在Python里使用open函数(方法)可以访问文件。

基本格式是:open([, access_mode])

这里的文件地址是文本形式,在Windows里,由于文件地址是使用反斜杠(),所以,可以使用r来对反斜杠不进行转译。

open(r’C:mydirmyfile’)

访问模式里是参数,默认是r(读取),其他方式下面还会有提及。

在访问模式,每一种方法都有一种使用到b的方式,就是二进制模式。这个在Python 2.x里没有区别,因为python2.x默认是二进制模式,在Python3.x里默认的字符是unicode方式。

正常使用文本的时候,不需要使用二进制方式,在需要特殊用途的时候是需要以二进制方式来存储、读取的。

操作模式:

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

三、文件的使用

• 迭代器是最好的读行工具 - 比如: 使用for循环 • 内容是字符串,不是对象 - 文件读取完之后,内容是以字符串的形式读取的。 • close是通常选项 - 当你使用完文件之后,使用close()方法来关闭文件关联。 • 文件是缓冲的而且是可查找的 - flush或close()方法可以直接存储缓存里的内容, seek方法可以转到指定位置。 当我们使用文件的时候,跟其它对象一样,用一个变量来引用。

>>> file = open('./test.txt','w')

然后对变量进行操作

>>> file.write('DoraEmon')  8

在这里,Python3.x是有返回输入长度,但Python2.x是没有的。

>>> file.close  >>> file = open('./test.txt','r')  >>> file.read()  'DoraEmon'

四、文件的读取

1、最基本的读取

读:当我们以r的模式读取文件后,可以用以下方法来读取内容。

PS C:UsersAdministrator>cat C:Testtest.txt  Dora  Emon

这里先是有一个提前创建的文件,文件名叫test.txt,在C:Test目录下。 read()方法就是从头到尾读一遍。刚刚读取文件后,其指针在最前面,读完之后指针在最后面,指针位置可以用tell()方法来查看。

>>> output = open(r'C:Testtest.txt')  >>> output.tell()  0  >>> output.read()  'DoranEmon'  >>> output.tell()  10

2、按需求读取

当我们需要只读取前4个字符,读到Dora:

>>> output = open(r'C:Testtest.txt')  >>> output.read(4)  'Dora'  >>> output.tell()  4

之后,就是从指针所指的地方开始读取:

>>> output.read()  'nEmon'

我们也可以按行读取:

>>> output = open(r'C:Testtest.txt')  >>> output.readline()  'Doran'  >>> output.readline()  'Emon'

也可以使用一个函数,把指针随意放在想要的位置,然后读取:

>>> output.seek(4)  4  >>> output.tell()  4  >>> output.read()  'nEmon'

五、文件的写入

1、基本写入

当我们需要写入到一个文件的时候,会使用w模式。当相应的文件存在时,会清空原先的文件然后写入,当相应的文件不存在时会创建新的文件。

>>> input = open(r'C:Testinput_test.txt','w')  >>> input.write('Dora Emon')  9  >>> input.write('DaXiong And JingXiang')  21  >>> input.flush()  >>> input.close()PS C:UsersAdministrator> cat C:Testinput_test.txt  Dora EmonDaXiong And JingXiang

在这里,flush()方法是把缓存里的内容写入硬盘中。当运行close()方法的时候,也会进行同样操作。

2、按列表内容写入

>>> lines = ['DoraEmonn','DaXiong And JingXiangn']  >>> input = open(r'C:Testinput_test.txt','w')  >>> input.writelines(lines)  >>> input.close()PS C:UsersAdministrator> cat C:Testinput_test.txt  DoraEmon  DaXiong And JingXiang

writelines是把列表里的元素一个一个输入进去。当然,元素里的字符串最后没有换行,最终结果也不是换行的。

3、在特定位置写入

>>> input = open(r'C:Testinput_test.txt','w')  >>> input.write('Dora')  4  >>> input.seek(0)  0  >>> input.write('Emon')  4  >>> input.close()PS C:UsersAdministrator> cat C:Testinput_test.txt  Emon

这里的话,当我们输入错误的时候,可以把指针挪到最前面,然后继续输入。seek可以有两个传递变量,只有一个变量时,就是更改当前的指针,或者第一个变量为0,第二个变量为1的时候,会返回当前指针位置,这个与tell方法同样。最后,第一个变量为0,第二个变量为2的时候会把指针放到最后。

4、在最后写入

之前看到的w模式,当文件是已有文件,就会删除里面的所有内容后再写入的。当我们需要在最后添加,而不是删除原有内容时,可以使用a模式。

>>> file = open(r'C:Testtest.txt','r')  >>> file.read()  'DoranEmon'  >>> file.close()  >>> file = open(r'C:Testtest.txt','a')  >>> file.write('DaXiong')  7  >>> file.close()PS C:UsersAdministrator> cat C:Testtest.txt  Dora  EmonDaXiong

我们会看到,a模式不会去更改原来的文件,而且每次写入也不会更改之前写入的内容。

六、文件的读写

在模式里,我们会看到r+, w+, a+ 三种模式都有读写的方法。 r+模式,只能打开已有文件,打开时保留原有文件,对文件可读,可写,也可更改原有内容。打开时指针在文件最前面。 w+模式,打开时没有相应文件,会创建;有相应文件,会删除里面所有内容后打开。之后的操作与r+完全相同。 a+模式,可以打开原有文件,也可创建新的文件,打开时指针为文件的最后位置。指针可以放到任何位置来读内容,但写入时,指针默认会移动到最后,然后写入。

模式 打开已有文件 打开新的文件 打开时指针位置 写入时指针位置 r+ 保留内容 发生错误 文件开头 当前位置 w+ 删除内容 创建文件 文件开头 当前位置 a+ 保留内容 创建文件 文件尾端 文件尾端

其余模式可参考https://blog.csdn.net/qq_35203425/article/details/80904428

七、文件的访问 – b模式

在Python里可以使用二进制方式读取和写入文件。 这个模式,在Python2.x里不会有什么特别,因为在2.x里存储方式就是二进制方式。

>>> a = '啊'  >>> a  'xe5x95x8a'

但是在Python3.x里是unicode方式:

>>> a = '啊'  >>> a  '啊'

所以在存储的时候,我们可以使用二进制模式,或者正常模式。

>>> a='啊'.encode()  >>> a  b'xe5x95x8a'

这之后,可以使用二进制方法来存储。

八、文件与其他类型 – 原生对象的存取

存储一些对象的时候,比如说列表,字典等;Python都需要把这些对象转换成字符串后存储:

>>> file = open(r'C:Testtest.type','w')  >>> file.write({'a':97})  Traceback (most recent call last):   File "<stdin>", line 1, in <module>  TypeError: write() argument must be str, not dict  >>> file.write(str({'a':97}))  9  >>> file.write(str([1,2]))  6  >>> file.close  <built-in method close of _io.TextIOWrapper object at 0x00000256209BF558>PS C:UsersAdministrator> cat C:Testtest.type  {'a': 97}[1, 2]

这样,读取的时候会出现我们得再次转换的问题,这个时候,我们可以用pickle模块:

>>> import pickle  >>> file = open(r'C:Testtest.type','wb')  >>> a = {'a',97}  >>> pickle.dump(a,file)  >>> file.close()PS C:UsersAdministrator> cat C:Testtest.type  €cbuiltins  set  q ]q(KaX   aqe卶Rq.    >>> file = open(r'C:Testtest.type','rb')  >>> a = pickle.load(file)  >>> a  {97, 'a'}PS C:UsersAdministrator> cat C:Testtest.type  {'a': 97}[1, 2]  q ]q(KaX   aqe卶Rq.

pickle.dump(obj, file[, protocol]) 序列化对象,并将结果数据流写入到文件对象中。参数protocol是序列化模式,默认值为0,表示以文本的形式序列化。protocol的值还可以是1或2,表示以二进制的形式序列化。 pickle.load(file) 反序列化对象。将文件中的数据解析为一个Python对象。 关于pickle模块详细介绍可以参考https://blog.csdn.net/sxingming/article/details/52164249

九、文件操作中会用到的其它工具

在Python里,我们可以使用os模块里的方法对文件进行操作:

PS C:UsersAdministrator> cd C:Test  PS C:Test> echo '' > file  PS C:Test> ls     目录: C:Test  Mode                LastWriteTime         Length Name  ----                -------------         ------ ----  -a----        2019/1/29     16:35              6 file    >>> import os  >>> os.rename(r'C:Testfile',r'C:Testfile2')  #重命名文件      PS C:Test> ls     目录: C:Test  Mode                LastWriteTime         Length Name  ----                -------------         ------ ----  -a----        2019/1/29     16:35              6 file2    >>> os.remove(r'C:Testfile2')  #删除文件    PS C:Test> ls  #此时因为file2已经被删除了,文件夹没有文件了,因此并没有ls出来结果      >>> os.getcwd()  #获取当前工作路径  'C:\Users\Administrator'  >>> os.chdir(r'C:Test')  #改变工作目录  >>> os.getcwd()  'C:\Test'

其他关于os模块的详细用法可以参考https://www.cnblogs.com/cherishry/p/5725977.html