Python文件操作

提醒:本文依据b站黑马python课整顿

链接指引 => 2022新版黑马程序员python教程

一、文件的编码

计算机中有许多可用编码:

  • UTF-8
  • GBK
  • Big5
UTF-8是目前全球通用的编码格局
除非有非凡需要,否则,一律以UTF-8格局进行文件编码即可。

二、文件的读取

2.1 open()关上函数

留神:此时的fopen函数的文件对象,对象是Python中一种非凡的数据类型,领有属性和办法,能够应用对象.属性或对象.办法对其进行拜访,后续面向对象课程会给大家进行具体的介绍。
name:是要关上的指标文件名的字符串(能够蕴含文件所在的具体门路)。mode:设置关上文件的模式(拜访模式):只读、写入、追加等。encoding:编码格局(举荐应用UTF-8)open(name, mode, encoding)

例子:

f = open('./test.txt', 'r', encoding='utf-8')

2.2 mode罕用的三种根底拜访模式

模式形容
f以只读形式关上文件。文件的指针将会放在文件的结尾。这是默认模式。
w关上一个文件只用于写入。如果该文件已存在则关上文件,并从结尾开始编辑,原有内容会被删除 。
如果该文件不存在,创立新文件
a关上一个文件用于追加。如果该文件已存在,新的内容将会被写入到已有内容之后
如果该文件不存在,创立新文件进行写入

2.3 读操作相干办法

操作汇总

操作性能
文件对象 = open(file, mode, encoding)关上文件取得文件对象
文件对象.read(num)读取指定长度字节<br/>不指定num读取文件全副
文件对象.readline()读取一行
文件对象.readlines()读取全副行,失去列表
for line in 文件对象for循环文件行,一次循环失去一行数据
文件对象.close()敞开文件对象
with open() as f通过with open语法关上文件,能够主动敞开

2.3.1 read()办法:

# num示意要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就示意读取文件中所有的数据。文件对象.read(num)

2.3.2 readlines()办法:

readlines能够依照行的形式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素。

f = open('python.txt')content = f.readlines()# ['hello world\n', 'abcdefg\n', 'aaa\n', 'bbb\n', 'ccc']print(content)# 敞开文件f.close()

例:
readline()办法:一次读取一行内容

f = open('python.txt')content = f.readline()print(f'第一行:{content}')content = f.readline()print(f'第二行:{content}')# 敞开文件f.close()

for循环读取文件行:

for line in open("python.txt", "r"):    print(line)# 每一个line长期变量,就记录了文件的一行数据

2.3.3 close() 敞开文件对象

f = open("python.txt", "r")f.close()# 最初通过close,敞开文件对象,也就是敞开对文件的占用# 如果不调用close,同时程序没有进行运行,那么这个文件将始终被Python程序占用。

2.3.4 with open 语法

with open("python.txt", "r") as f:    f.readlines()# 通过在with open的语句块中对文件进行操作# 能够在操作实现后主动敞开close文件,防止忘记掉close办法

案例:通过文件读取操作,读取此文件,统计itheima单词呈现的次数

itheima python itcastbeijing shanghai itheimashenzhen guangzhou itheimawuhan hangzhou itheimazhengzhou bigdata itheima
index = 0with open('./test.txt', 'r', encoding='utf-8') as f:    for line in f:        line = line.strip()        # print(line)        str = line.split(' ')        print(str)        for val in str:            if val == 'it':                index += 1print(f'index:{index}')

三、文件的写入

3.1 写操作疾速入门

留神:

  • 间接调用write,内容并未真正写入文件,而是会积攒在程序的内存中,称之为缓冲区

    • 当调用flush的时候,内容会真正写入文件
    • 这样做是防止频繁的操作硬盘,导致效率降落(攒一堆,一次性写磁盘)
    • 文件如果不存在,应用”w”模式,会创立新文件
    • 文件如果存在,应用”w”模式,会将原有内容清空

例:

# 1. 关上文件f = open('python.txt', 'w')# 2.文件写入f.write('hello world')# 3. 内容刷新f.flush()

四、文件的追加

4.1 追加写入操作疾速入门

留神:

  • a模式,文件不存在会创立文件
  • a模式,文件存在会在最初,追加写入文件

案例演示:

# 1. 关上文件,通过a模式关上即可f = open('python.txt', 'a')# 2.文件写入f.write('hello world')# 3. 内容刷新f.flush()

五、文件操作综合案例

实现文件备份案例:

bill.txtname,date,money,type,remarks周杰轮,2022-01-01,100000,生产,正式周杰轮,2022-01-02,300000,支出,正式周杰轮,2022-01-03,100000,生产,测试林俊节,2022-01-01,300000,支出,正式林俊节,2022-01-02,100000,生产,测试林俊节,2022-01-03,100000,生产,正式林俊节,2022-01-04,100000,生产,测试林俊节,2022-01-05,500000,支出,正式张学油,2022-01-01,100000,生产,正式张学油,2022-01-02,500000,支出,正式张学油,2022-01-03,900000,支出,测试王力鸿,2022-01-01,500000,生产,正式王力鸿,2022-01-02,300000,生产,测试王力鸿,2022-01-03,950000,支出,正式刘德滑,2022-01-01,300000,生产,测试刘德滑,2022-01-02,100000,生产,正式刘德滑,2022-01-03,300000,生产,正式
f2 = open('bill.txt.bak', 'a', encoding="utf-8")with open('bill', 'r', encoding="UTF-8") as f:    for line in f:        line = line.strip()        str = line.split(',')        if str[4] == '测试':            continue        else:            f2.write(f'{line}\n')f2.close()

总结

以上就是Python文件操作,之后会继续更新,欢送大家点赞关注呀~~