文件就是把一些数据存储存放起来,可以让程序下一次执行的时候直接使用,而不必重新制作一份,省时省力.

python操作文件的步骤

1.将文件抽象成一个python的对象

2.对这个对象,进行读/写的动作

3.关闭这个对象

一. 打开文件

在python,使用open函数,可以打开一个已经存在的文件,或者创建一个新文件。与其翻译成打开,不如翻译成从系统中申请一个操作文件的对象。

语法:

open(文件名,访问模式)

案例1:

图片1.png

运行结果:

注意事项:

文件不存在,会在当前代码所在的目录创建该文件.

"""

r 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。

w 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

a 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。

rb 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。

wb 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

ab 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。

r+ 打开一个文件用于读写。文件指针将会放在文件的开头。

w+ 打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

a+ 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。

rb+ 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。

wb+ 以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

ab+ 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

"""

注意:

1.在学习过程中: 如果是文本文件,强烈建议使用encoding = utf-8

2.在工作过程中: 要看该文件的实际编码是什么

二. 关闭文件

语法:

文件变量.close()

运行结果:

无运行结果

三. 把数据写在文件中

语法:

文件.write("数据") 文件数据写的通用操作

文件.writelines([ ]) 文本文件的操作,每个元素

案例:

fp.write('1111\n') #可以换行

fp.write('2222')

fp.writelines(['3333','4444'])

注意事项:

f.write()可以多次调用. 向文件中写入多次数据

2.f.writelines()可以多次调用. 向文件中写入多次数据

3.w 默认会将原来的内容覆盖掉.

四. 从文件中读取数据

1>.读取指定个数的字符

语法:

文件.read(字符个数) #参数不写表示读取文件中的全部信息

注意事项:

1. f.read()可以多次调用. 但每次调用会在原来的基础上面一直向后读取

2. r 表示要读取文件中的内容,但是不可写入数据 io.UnsupportedOperation: not writable

3. 如果文件不存在将会报错。FileNotFoundError: [Errno 2] No such file or directory: '1data.txt'

上面的英文说明文件找不到, 文件或者目录不存在

4. open的打开模式默认为r,所以第二个参数可以省略

2>. 一行一行从文件中读取数据

语法:

列表=文件.readlines() #读取文件中所有行并且将每行数据放在列表中返回。列表中的元素就是文件中的每行数据

案例:

#读取所有行,放在列表中

result=fp.readlines()

字符串 = 文件.readline() #一次性读取一行文件中的数据

两种读取的区别:

1.f.readlines() 一次性将每一行读取出来保存在列表中

2.f.readline() 一行一行读取

3.如果文件过大,readlines一次性读取出来大致超过电脑的内存。建议使用readline

4.如果文件很小,建议使用readlines一次性读取

注意事项:

每调用一次readline()才会读取一行数据

更多推荐

python打开一个不存在的文件报错,python中的文件操作(一)