文件操作
对文件操作流程
- 打开文件,得到文件句柄并赋值给一个变量
- 通过句柄对文件进行操作
- 关闭文件
基本操作
1 2 3 4 5 6 7 8 |
|
打开文件的模式有:
- r,只读模式(默认)。
- w,只写模式。【不可读;不存在则创建;存在则删除内容;】
- a,追加模式。【可读; 不存在则创建;存在则只追加内容;】
"+" 表示可以同时读写某个文件
- r+,可读写文件。【可读;可写;可追加】
- w+,写读
- a+,同a
"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用)
- rU
- r+U
"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)
- rb
- wb
- ab
注意:
1、用这种方式读取:,避免readline的方式一次性读取大文件,内存占用过大
f = open("file",r+)
for line in f
print(line)
2、替换字符串,方法一:读行,每行替换字符串,逐行写入新文件
f = open("file",r)
f_new=open("file_new",rw)
str_old="aa"
str_new="bb"
for line in f
if str_old in line
line=line.replace(str_old,str_new)
f_new.write(line)
3、用with方法防止未关闭文件占用内存
with open("file1") as f1,open("file2") as f2:
高阶函数
变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。
1 2 3 4 5 6 |
|
装饰器
高阶函数 + 嵌套函数 -> 装饰器
上述有个问题,只能装饰 不传参的函数, 若test1(*args)需传参,需修改
def(*args,**kwargs):
....
func(*args,**kwargs)
即可
生成器
通过列表生成式,我们可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了。
所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间。在Python中,这种一边循环一边计算的机制,称为生成器:generator。
要创建一个generator,有很多种方法。第一种方法很简单,只要把一个列表生成式的[]
改成()
,就创建了一个generator:
1 2 3 4 5 6 |
|
创建L
和g
的区别仅在于最外层的[]
和()
,L
是一个list,而g
是一个generator。
我们可以直接打印出list的每一个元素,但我们怎么打印出generator的每一个元素呢?
如果要一个一个打印出来,可以通过next()
函数获得generator的下一个返回值: