编码就是一种规则集合,记录了内容和二进制间进行相互转换的逻辑。

在日常生活中,文件操作主要包括打开、关闭、读、写等操作
只有操作文件与python文件在同一目录才能直接写文件名。

新手建议都写文件的绝对路径,不易导致错误发生。
open(name, mode, encoding)
# name:是要打开的目标文件名的字符串(可以包含文件所在的具体路径)。
# mode:设置打开文件的模式(访问模式):只读、写入、追加等。
# encoding:编码格式(推荐使用UTF-8)f = open("C:/code/bill.txt", "r", encoding="UTF-8")
# encoding的顺序不是第三位,所以不能用位置参数,用关键字参数直接指定
# f是open函数的文件对象,可以使用对象.属性或对象.方法对其进行访问| 模式 | 描述 |
|---|---|
| r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
| w | 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,原有内容会被删除。如果该文件不存在,创建新文件。 |
| a | 打开一个文件用于追加。如果该文件已存在,新的内容将会被写入到已有内容之后。 如果该文件不存在,创建新文件进行写入。 |
| 操作 | 功能 |
|---|---|
| 文件对象.read(num) | 读取指定长度字节 不指定num读取文件全部 |
| 文件对象.readline() | 读取一行 |
| 文件对象.readlines() | 读取全部行,返回列表 |
| for line in 文件对象 | for循环文件行,一次循环得到一行数据 |
| 文件对象.close() | 关闭文件对象 |
| with open() as f | 通过with open语法打开文件,可以自动关闭 |

f = open("C:/code/test.txt", "r", encoding="UTF-8")
content = f.read() # 不传入num,读取文件中所有的数据。
print(content)
# 打印
# 观止
# study
f = open("C:/code/test.txt", "r", encoding="UTF-8")
content = f.read(2) # 传入num,读取2字节长度数据。
print(content)
# 打印
# 观止f = open("C:/code/test.txt", "r", encoding="UTF-8")
content = f.readline()
print(f"第一行内容:{content}") # 打印 第一行内容:观止
content = f.readline()
print(f"第二行内容:{content}") # 打印 第二行内容:studyf = open("C:/code/test.txt", "r", encoding="UTF-8")
content = f.readlines()
print(content) # 打印 ['观止\n', 'study']
print(type(content)) # 打印 <class 'list'># 每一个line临时变量,就记录了文件的一行数据
for line in open("C:/code/test.txt", "r", encoding="UTF-8"):
print(line)
# 打印
# 观止
#
# studyf = open("C:/code/test.txt", "r", encoding="UTF-8")
# 需要执行代码
f.close()
with open() as fwith open("C:/code/test.txt", "r", encoding="UTF-8") as f:
f.readlines()f = open("C:/code/test.txt", "w")
# 文件如果不存在,使用”w”模式,会创建新文件
# 文件如果存在,使用”w”模式,会将原有内容清空
# 2.文件写入
f.write('hello world')
# 3. 内容刷新
f.flush()
write,内容并未真正写入文件,而是会积攒在程序的内存中,称之为缓冲区flush的时候,内容会真正写入文件f = open("C:/code/test.txt", "a")
# 2.文件写入
f.write('study')
# 3. 内容刷新
f.flush()

阅读量:538
点赞量:0
收藏量:0