计算机只能识别0和1,那么我们丰富的文本文件是如何被计算机识别,并存储在硬盘中呢?
使用编码技术(密码本)将内容翻译成0和1存入
编码技术即翻译的规则,记录了如何将内容翻译成二进制,以及如何将二进制翻译回可识别内容
计算机中的编码有:UTF-8,GBK,Big5等
使用open函数,可以打开一个已经存在的文件,或者创建一个新文件,语法如下:
open(name,mode,encoding)
name:是要打开的目标文件名的字符串(可以包含文件所在的具体路径)
mode:设置打开文件的模式(访问模式):只读、写入、追加等。
encoding:编码格式(推荐使用UTF-8)
示例代码:
f = open('python.txt','r',encoding='UTF-8')
#encoding的顺序不是第三位,所以不能使用位置参数,而是用关键字参数直接指定
此时的 f 是open函数的对象
mode访问模式
模式 | 描述 |
---|---|
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
w | 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,原有内容会被删除。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
read()方法:
文件对象.read(num)
num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据。
f = open('python.txt','r',encoding='UTF-8')
print(type(f))
print(f.read(10))
readlines()方法:
readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素。
f = open('python.txt','r',encoding='UTF-8')
lines = f.readlines()
print(type(lines))
print(lines)
readline()方法:一次读取一行内容
f = open('python.txt','r',encoding='UTF-8')
print(f.readline())
print(f.readline())
print(f.readline())
for循环读取文件行
f = open('python.txt','r',encoding='UTF-8')
for line in f:
print(line)
close():关闭文件对象
f.close()
如果不调用close,同时程序没有停止运行,那么这个文件将一直被python程序占用
with open 语法
with open("python.txt","r",encoding='UTF-8') as f:
print(f.readlines())
通过在with open的语句块中对文件进行操作,可以在操作完成后自动关闭文件
write():文件写入
flush():内容刷新
f = open('python.txt','w',encoding='UTF-8')
f.write("Hello world!")
f.flush()
f.close()
直接调用write,内容并未真正写入文件,而是会积攒在程序的内存中,称之为缓冲器
当调用flush的时候,内容会真正写入文件
这样做是避免频繁地操作硬盘,导致效率下降(攒一堆,一次性写磁盘)
如果不想删除原有内容,而是在后面追加内容,要使用a模式