1.文件编码
编码就是一种规则集合,记录了内容和二进制间进行相互转换的逻辑。
编码有许多种,我们最常使用的是UTF-8编码
为什么需要使用编码
计算机只认识0和1,所以需要将内容翻译为0和1才能保存到计算机种,同时也需要编码,将计算机保存的0和1翻译为可识别的内容
2.文件读取
一篇文章、一段视频、一个可执行程序,都可以被保存为一个文件,并赋予一个文件名。操作系统以文件为单位管理磁盘中的数据。一般来说,文件可分为文本文件、视频文件、音频文件、图像文件、可执行文件等多种类别。
open()打开函数
语法
open(name, mode, encoding)
name: 是要打开的目标文件名的字符串(可以包含文件所在的具体路径)
mode: 设置打开文件的模式(访问模式):只读、写入、追加
encoding: 编码格式(推荐使用UTF-8)
示例代码:
f = open('python.txt', 'r', encoding="UTF-8")
#ecoding的顺序不是第三位,所以不能用位置参数,要用关键参数直接指定
注意事项:
此时的’f‘ 是 ‘open’ 函数的文件对象,对象是Python中的一种特殊数据类型,拥有属性和方法,可以使用对象.属性或方法对其进行访问。
(1)读相关操作
read()方法:
文件对象.read(num)
num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据
readlines()方法
readlines可以按照行的方式把整个文件中的内容进行一次行读取,并且返回的是一个列表,其中每一行的数据为一个元素
f = open('python.txt')
content = f.readlines()
#['hello world\n', 'abcdefg\n', 'bbb\n', 'ccc']
print(content)
#关闭文件
f.close()
readline()方法,一次性读取一行内容
f = open('python.txt')
content = f.readline()
print('第一行:{content}')
content = f.readline()
print('第二行:{content}')
#关闭文件
f.close()
最后通过close, 关闭文件对象,也是关闭对文件的占用
如果不调用,同时程序没有停止运行,那么这个文件将一直被Python程序占用
for 循环读取文件行
for line in open('python.txt', 'r',encoding='UTF-8'):
print(line)
#line记录一行的数据
with open语法
with open('python.txt', 'r', encoding='UTF-8') as f:
f.readlines()
#通过在with open的语句块中对文件进行操作
#可以在操作完成后自动关闭close文件,避免遗忘掉close方法
3.文件写入
#1.打开文件
f = open('python.txt', 'w', encoding="UTF-8")
#2.文件写入
f.write('hello world')
# 3. 内容刷新
f.flush()
注意:
直接调用write, 内容并未真正写入文件,而是会积攒在程序的内存中,称之为缓冲区
当调用flush的时候,内容会真正写入文件
这样做事避免频繁的操作硬盘,导致效率下降(攒一堆,一次性写磁盘)
# 文件不存在时会创建文件
import time
# f = open('hello.txt', 'w', encoding='UTF-8')
# f.write('hello world!!!hhhh')
# # time.sleep(60000)
# f.flush()
# f.close()
# 文件存在时,会清空全部内容,重新写入
f = open('hello.txt', 'w', encoding='UTF-8')
f.write('你好呀')
# f.flush()
f.close()
4.文件追加
# 1.打开文件,通过a模式打开即可
f = open('python.txt', 'a')
# 2.文件写入
f.write('hello world')
# 3. 内容刷新
f.flush()
注意:
a模式下文件不存在会创建文件;文件存在会在最后追加写入文件
# 文件追加
f = open('hello.txt', 'a', encoding='UTF-8')
f.write('\n暴富暴富,变有钱')
f.close()