文件基本操作:
现有文件file.txt
1 f=open('file.txt','r')#以只读方式打开一个文件,获取文件的句柄,如果是读的话,r可以不写,默认就是只读;文件不存在时,会报错2 first_line=f.readline()#获取文件的第一行内容,返回的是一个list3 print(first_line)#打印第一行4 res=f.read()#获取除了第一行剩下的所有文件内容5 print(res)6 f.open()#关闭文件 7 f.read()#读取文件里面所有的内容,返回的是字符串 8 f.readline()#只读取一行的内容,返回的是字符串 9 f.readlines()#读取文件里面所有的内容,返回的是一个list #list里每个元素是每行的数据 10 f.write()#只能写字符串 11 f.writelines()写可迭代对象
打开文件时,需要指定文件路径和以何等方式打开文件,打开后,即可获取该文件句柄(句柄理解为该文件),后面通过此文件句柄对该文件操作,
打开文件的模式有:
r,只读模式(默认)
w,只写模式。【不可读;不存在则创建;存在则删除以前的内容,然后写入新的内容】
a,追加模式。【不可读;不存在则创建;存在则只追加内容】
“+”表示可以同时读写某个文件:
r+,【可读,可写;可追加,如果打开的文件不存在的话,会报错】
w+,【写读模式,使用w+的话,已经存在的文件内容会被清空,可以读到已经写的文件】
a+,【追加读写模式,不存在则创建;存在则只追加内容】
1 f=open('ybq.txt','a+',encoding='utf-8') 2 f.seek(0)#seek移动指针的时候,只对读好使,对写不好使 3 print(f.read())#读取文件里面的全部内容 4 f.write('yunbenking'+'\n') 5 f.truncate()#清空文件内容 6 f.tell()#查看当前文件指针的位置 7 print(f.readline())#只读取一行的内容 8 print(f.readlines())#读取文件里面的所有内容,把文件里面每一行的内容放到一个list 9 for k in f:10 print(k)11 names=['ybq','mpp','tlx','ply','yjy']12 st='ybq,mpp,tlx'13 tu=('sdf','sdfs','sdfsd')14 f.write(names)#必须是字符串类型15 f.writelines(names)#写入的时候,传入一个可迭代对象就行了16 f.close()
高效处理文件:
1 fw=open('ybq.txt') 2 count=1 3 #直接循环文件对象的话,就是循环文件里面的每一行 4 for f in fw: 5 print('第%s行'%count,f) 6 count+=1 7 8 for f in fw: 9 f=f.strip()10 stu_lst=f.split(',')11 print(stu_lst)
写入文件的方法:
方法一:write将list写入文件,write写入字符串
1 names=['a','b','c']2 for name in names:3 f.write(name)
方法二:writelines直接写入,writelines传入可迭代对象,会先循环
1 names=['a','b','c']2 f.writelines(names)
1 s='dingfei,123456'2 f.write(s)#直接写入字符串,所以可以直接写入,效率高3 f.writelines(s)#写入可迭代对象,所以先循环字符串,所以效率不高
1 import time2 f=open('hahah','w')3 f.write('sdfggg')4 f.flush()#立即把缓冲区里面的内容写到磁盘里面,写入的时候需要缓冲区满了才会写到磁盘里5 time.sleep(50)
with的用法:
1 with open('a.txt','w') as gy:2 gy.write('hhh')#自动的当文件不在用时直接关掉3 4 5 6 #打开多个文件7 with open('a.txt','w') as gy,open('b.txt') as gy2:8 gy.write('hhh')9 gy2.write('sdfs')
打开图片样式:
1 f=open('5.png','rb')#bytes,以二进制模式打开2 print(f.read())
修改文件:将下列歌词中的‘一’全部换成‘二’
寂寞当然有一点 你不在我身边 总是特别想念你的脸 距离是一份考卷 测量相爱的誓言 最后会不会实现 我们为爱还在学 学沟通的语言 学着谅解 学着不流泪 等到我们学会飞 飞越黑夜和考验 日子就要从孤单里毕业 我们用多一点点的辛苦 来交换多一点点的幸福 就算幸福 还有一段路 等我们学会忍耐和付出 这爱情一定会有张证书 证明 从此不孤独 从此不孤独
方法一:将文件完全替换后,清空内容,再重新写入
1 with open('geci','a+',encoding='utf-8') as f:2 f.seek(0)3 all=f.read()4 new_all=all.replace('二','一')5 f.seek(0)6 f.truncate()#把文件内容清空7 f.write(new_all)8 f.flush()
方法二:
1 import os2 with open('geci','a+',encoding='utf-8') as f,open('geci.bak','w',encoding='utf-8') as f2:#直接打开两个文件3 f.seek(0)4 for line in f:5 new_line=line.replace('一','二')6 f2.write(new_line)#把文件geci里修改的内容写入到文件geci.bak7 os.remove('geci')#删除第一个文件8 os.rename('geci.bak','geci')#将第二个文件的名字改为第一个
集合:
集合也是一种数据类型,一个类似列表的东西,它的特点是无序的,不重复的,也就是说集合中是没有重复的数据。天生去重!
集合的作用:
1.它可以把一个列表中重复的数据去掉,不需要再写判断
2.可以做关系测试。取交集,并集,差集
定义集合:
1 s=set()#定义了一个空的集合2 s2={ '1','2','3'}#这种方式是直接定义一个集合;如果有冒号是字典,没有冒号就是集合3 list=[2,3,1,2,3,4]4 s_list=set(list)#这样就定义了一个集合5 set1=set([1,3,4,5,6])#这种方式和上面的都是把list转换成一个集合
集合操作:
1 list1={1,2,3,4,5,6,9} 2 list2={2,3,4,6,1} 3 list3={1,2,3} 4 print(list1.intersection(list2))# 取交集,也就是取list1和list2中都有的 5 print(list1&list2)# 取交集,也就是取list1和list2中都有的 6 print(list1.union(list2))# 取并集,也就是把list1和list2合并了,然后去除重复的 7 print(list1 | list2)# 取并集 8 print(list1.difference(list2))#取差集 在list1中存在,在list2中没有的 9 print(list1 - list2)10 list1.add(888)#添加元素11 list1.update([777,666,666])#添加元素12 list1.remove(777)#删除元素,如果元素不存在会报错13 list1.pop()#删除一个随机的元素,并返回删除的元素14 list1.discard('dddd')#如果删除的元素存在,删除,不存在不做处理