文件模式modo
文件模式 | 操作 |
r | 以读方式打开(默认) |
rU或者U | 以读方式打开,同时提供通用换行符支持 |
w | 以写方式打开,必要时清空 |
a | 以追加模式打开,从EOF开始,必要时创建新的文件 |
r+ | 以读写方式打开 |
w+ | 以写读方式打开 |
a+ | 以追加模式打开 |
rb | 以二进制读模式打开 |
ab | 以二进制追加模式打开 |
wb | 以二进制写模式打开 |
rb+ | 以二进制读写模式打开 |
ab+ | 以二进制追加模式打开 |
wb+ | 以二进制写读模式打开 |
文件方法method
文件对象方法 | 操作 |
file.close() | 关闭文件 |
file.fileno() | 文件描述符 |
file.flush() | 刷新文件的内部缓冲区 |
file.isatty() | 判断file是否是一个类tty设备 |
file.next() | 返回文件的下一行类似于file.readline() |
file.read() | 从文件读取size个字节,当未给定或给定负值的时候,读取剩余的所有字节,饭后作为字符串返回 |
file.readinto(buf,size) | 读取size个字节到文件缓冲器中 |
file.readline(size) | 从文件中读取并返回一行(包括行结束符),或返回最大size个字符 |
file.readlines(sizhint=0) | 读取文件的所有行并作为一个列表返回(包含所有行的结束符);如果给定了sizhint且大于0,那么将返回总和大约为sizhit字节的行(大小由缓冲器容量的下一个值决定)(比如说缓冲器的大小只能为4K的倍数,如果sizhint的值为15k则返回的可能是16k) |
file.seek(off,whence=0) | 在文件中移动文件指针,从whence(0代表文件开始,1代表当前位置,2代表文件末尾)偏移off字节 |
file.tell() | 返回当前文件中的位置 |
file.truncate(size=file.tell()) | 截取文件到最大size字节,默认为当前文件位置 |
file.write() | 向文件写入字符串 |
file.writelines() | 向文件写入字符串序列seq |
文件属性property
文件对象属性 | 操作 |
file.closed | 表示文件已经被关闭,否则为False |
file.encoding | 文件编码 |
file.mode | 打开模式 |
file.name | 文件名 |
file.newlines | 表示文件所采用的分隔符 |
file.softspace | 为0表示在输出一数据后,要再加上一个空格符,为1表示不加,这个属性一般用不到 |
实例演示
文件操作:打开-操作-关闭
模式mode
• 文本
• r只读(默认)
• w只写(创建新文件,存在则删除,不存在则新建)
• a追加(不存在则创建,存在则追加)
• “+”表示可以同时读写某个文件
• r+读写(追加写,常用此项),w+写读(追加写),a+追加读(同a)
• “b”二进制文件(没有encoding参数,网络传输,图片,声音,视频)
• rb只读,rw只写,ra追加,rb+读写,rw+读写,ra+读写
• “U”表示读取时,\r,\n,\r\n自动换成\n
• rU只读
只读(默认)
1 __author__ = "KuanKuan"
2 f = open("沁园春·雪.txt",encoding="utf-8")
3 print(f.read())
4 f.close()
5 """""
6 报错:
7 UnicodeDecodeError: 'gbk' codec can't decode byte 0xae in position 4:
8 illegal multibyte sequence
9 设置:encoding="utf-8"
10 """""
只写,原来的内容被清空,相当于新建了一个文档
1 __author__ = "KuanKuan"
2 f = open("沁园春·雪.txt","w",encoding="utf-8")
3 shopping = f.write("1.苹果手机 9999元\n"
4 "2.华为手机 2333元\n"
5 "3.小米手机 4999元\n"
6 "4.猫屎咖啡 31元\n"
7 "5.狗粮 122元\n"
8 "6.电影票 72元\n"
9 "7.冰淇淋 52元\n"
10 "8.电视机 1000元\n"
11 "9.电冰箱 2300元\n"
12 "10.外星人笔记本 23500元")
13 f.close()
追加
1 __author__ = "KuanKuan"
2 f = open("沁园春·雪.txt","a",encoding="utf-8")
3 f.write("\n好贵好贵买不起买不起!")
4 f.close()
读写文件
1 __author__ = "KuanKuan"
2 f = open("沁园春·雪.txt","r+",encoding="utf-8")
3 # 只适合读取小文件,会转为列表(low loop,不推荐)
4 for index,line in enumerate(f.readlines()):
5 if index == 1:
6 print("我是分隔符".center(50,"-"))
7 continue
8 print(line.strip())#去除两侧的空格和换行符
9 f.write("写入内容不会报错!")
10 f.close()
11 """
12 1.苹果手机 9999元
13 ----------------------我是分隔符-----------------------
14 3.小米手机 4999元
15 4.猫屎咖啡 31元
16 5.狗粮 122元
17 6.电影票 72元
18 7.冰淇淋 52元
19 8.电视机 1000元
20 9.电冰箱 2300元
21 10.外星人笔记本 23500元好贵好贵买不起买不起!
22 好贵好贵买不起买不起!
23 """
写读文件
__author__ = "KuanKuan"
f = open("沁园春·雪.txt","r+",encoding="utf-8")
# high biger,推荐
count = 0 #计数器
for line in f: #f是一个迭代器
count += 1
if count == 2:
print("-"*50)
continue
print(line.strip())
f.close()
"""
1.苹果手机 9999元
--------------------------------------------------
3.小米手机 4999元
4.猫屎咖啡 31元
5.狗粮 122元
6.电影票 72元
7.冰淇淋 52元
8.电视机 1000元
9.电冰箱 2300元
10.外星人笔记本 23500元好贵好贵买不起买不起!
好贵好贵买不起买不起!
好贵好贵买不起买不起!写入内容不会报错!
"""
文件对象方法和属性
1 __author__ = "KuanKuan"
2 f = open("沁园春·雪.txt","r+",encoding="utf-8")
3
4 print(f.tell()) # 文件指针位置 ->0
5 print(f.readline()) # ->1.苹果手机 9999元
6 print(f.tell()) # ->24
7 f.seek(0) # 将文件指针移到文件首
8 print(f.tell()) # ->0
9 print(f.readline()) # ->1.苹果手机 9999元
10 print(f.fileno()) # 文件的描述符 ->3
11 print(type(f)) # -><class '_io.TextIOWrapper'>
12 print(f.name) # 文件名 ->沁园春·雪.txt
13 print(f.mode) # 打开模式 ->r+
14 print(f.closed) # 是否关闭 ->False
15 print(f.encoding) # 文件编码 ->utf-8
16 print(f.buffer) # -><_io.BufferedRandom name='沁园春·雪.txt'>
17 print(type(f.newlines),f.newlines.encode("utf-8")) # 文件换行符# -><class 'str'> b'\r\n'
18 print(f.isatty()) # 检测文件是否连接到一个终端设备 ->False
19 f.truncate(10) # 截断
20 f.flush() # 将缓存内容刷入硬盘
21 f.write("在增加点内容吧")
22 f.close()
23 """
24 0
25 1.苹果手机 9999元
26
27 24
28 0
29 1.苹果手机 9999元
30
31 3
32 <class '_io.TextIOWrapper'>
33 沁园春·雪.txt
34 r+
35 False
36 utf-8
37 <_io.BufferedRandom name='沁园春·雪.txt'>
38 <class 'str'> b'\r\n'
39 False
40 """
二进制读写
1 __author__ = "KuanKuan"
2 f = open("沁园春·雪.txt", "rb+") # 二进制读写的时候,不能指定编码
3 print(f.read()) # ->b'\xe6\x88\x91\xe7\x88\xb1\xe5\x8c\x97\xe4\xba\xac\xe5\xa4\xa9\xe5\xae\x89\xe9\x97\xa8'
4 f.write("我爱北京天安门".encode("utf-8")) # 字符串转为字节再写入
5 f.close()