day5 文件相关操作

文件操作

常见的文件类型

  • txt
  • csv
  • json
  • html
  • mp4

文件操作的流程

打开

  • open(file) 打开文件(创建一个file对象,之后才能用它调用相关的方法)
  • 格式:(mode为打开的模式,默认只读,encoding为编码方式,默认‘utf-8’)
模式描述
r以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
rb以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
r+打开一个文件用于读写。文件指针将会放在文件的开头。
rb+以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
w打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
w+打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb+以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
  • 格式:

    file_object=open(file,[,mode],[,encoding='utf-8'],[,buffering])
    
    f=open("./test.csv")
    print(f.read())
    
    

读/写

  • f.read([size])

    • 从文件中根据当前指针读取指定长度字节数,若未指定则读取当前指针之后的全部
    f=open("./test.csv")
    print(f.read())
    
    #序号,id,age,name
    #1,901,11,wang
    #2,902,14,li
    #3,903,15,tom
    

  • f.readline([size])
    • 读取整行,包括“\n”(size参数为返回行中的前多少个字节)
f=open("./test.csv")
print(f.readline())
print(f.readline())
print(f.readline())

#序号,id,age,name
#
#1,901,11,wang
#
#2,902,14,li
f=open("./test.csv")
for i in  f:
    print(i,end='')

    
# 序号,id,age,name
#1,901,11,wang
#2,902,14,li
  • f.readlines([size])
    • 取所有行,并返回列表,包括换行符(size参数为返回行中的前多少个字节)
f=open("./test.csv")
print(f.readlines())

#['序号,id,age,name\n', '1,901,11,wang\n', '2,902,14,li\n', '3,903,15,tom\n', #'4,904,15,jack\n', '5,905,21,han\n', '6,906,18,chen\n', '7,907,16,lucy\n', #'8,908,17,rose\n', '9,909,15,ruby\n']
  • f.write(str)
    • 将字符串写入文件,并返回字符串长度(如果文件不存在则新建一个并写入)
    • w模式打开文件会直接清空文件内容
    • 写入之后定位在末尾所以read()会为空,所以需要用seek()定位到开头才能读
f=open("./青花瓷.txt",'w+',encoding='utf-8')
f.write("1234567890")
print(f.read())
f.seek(0)
print(f.read())
f.close()

#
#1234567890
  • f.writelines(seq)
    • 向文件写入一个序列字符串列表。如果需要换行,需要自己加入换行符。
f=open("./青花瓷.txt",'w+',encoding='utf-8')
f.writelines(['123\n','456\n','789\n'])
f.flush()
f.seek(0)
print(f.read())

#123
#456
#789
  • f.flush()
    • 刷新文件缓冲,直接把内部缓冲的数据写入文件

文件的定位

  • f.seek(offset[,whence])
    • 设置文件的当前位置,即指针位置
      • offset ,起始偏移量
      • whence 可选,默认值为 0。给offset参数一个定义,表示要从哪个位置开始偏移;0代表从文件开头开始算起,1代表从当前位置开始算起,2代表从文件末尾算起。
f=open("./青花瓷.txt",'a+',encoding='utf-8')
f.seek(0,0)
print(f.read())
f.seek(1,0)
print(f.read())

#1234567890
#234567890
  • f.tell()
    • 返回值为文件的当前位置,即指针位置
f=open("./青花瓷.txt",'w+',encoding='utf-8')
f.write('1234567890')
print(f.tell())
f.close()

#10

关闭

  • close() 关闭文件
    • 节省计算机资源和提供性能,使用完文件之后,关闭它

实例

  • 随机生成100个数存入txt文件并读取
import random
f=open("./青花瓷.txt",'w+',encoding='utf-8')
for i in range(100):
    a=int(random.uniform(0,100))
    f.write(str(a)+' ')
f.flush()
f.seek(0)
print(f.read())
f.close()

#11 85 53 64 21 9 3 34 22 49 97 89 78 80 13 51 93 73 26 36 71 23 72 81 24 37 15 4 81 48 37 90 39 84 67 63 63 80 52 0 3 34 18 91 72 17 58 93 79 96 84 59 57 30 20 2 67 23 63 41 76 36 88 82 20 15 58 39 53 14 42 92 98 9 37 58 58 90 93 62 9 98 90 94 15 97 65 55 48 11 59 21 53 30 77 56 11 12 39 76 

文件对象的属性

属性描述
f.name返回文件的名称
f.mode返回文件的访问模式
f.closed如果文件关闭了返回True,反之返回False
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值