文件修改的两种方式
方式一:文本编辑采用的就是这种方式
实现思路:将文件内容发一次性全部读入内存,然后在内存中修改完毕后再覆盖写回原文件
优点: 在文件修改过程中同一份数据只有一份
缺点: 会过多地占用内存
with open('c.txt',mode='rt',encoding='utf-8') as f:
res=f.read() # 一次性读入
data=res.replace('alex','dsb')
print(data)
with open('c.txt',mode='wt',encoding='utf-8') as f1:
f1.write(data)
方式二:
实现思路:以读的方式打开原文件,以写的方式打开一个临时文件,一行行读取原文件内容,修改完后写入临时文件...,删掉原文件,将临时文件重命名原文件名
优点: 不会占用过多的内存
缺点: 在文件修改过程中同一份数据存了两份
import os
with open('c.txt', mode='rt', encoding='utf-8') as f,
open('.c.txt.swap', mode='wt', encoding='utf-8') as f1:
for line in f:
f1.write(line.replace('alex', 'dsb'))
os.remove('c.txt')
os.rename('.c.txt.swap', 'c.txt')
函数
1、为何要用函数
(1)组织结构不清晰,可读性差
(2)代码冗余
(3)可维护性、扩展性差
2、什么是函数
函数就相当于具备某一功能的工具
函数的使用必须遵循一个原则:先定义,后调用
3、如何用函数
㈠先定义
定义的语法:
def 函数名(参数1,参数2,...):
"""文档描述"""
函数体
return 值
形式一:无参函数
def 函数名():
函数体
形式二:有参函数
def 函数名(x,y):
print(x,y)
形式三:空函数,函数体代码为pass
def func(x, y):
pass
* 定义函数发生的事情
⑴申请内存空间保存函数体代码
⑵将上述内存地址绑定函数名
⑶定义函数不会执行函数体代码,但是会检测函数体语法
*调用函数发生的事情
⑴通过函数名找到函数的内存地址
⑵然后加括号就是在触发函数体代码的执行
(二)调用函数
1、语句的形式:只加括号调用函数
interactive()
add(1,2)
2、表达式形式:
def add(x,y):
res=x + y # 数学表达式
res=add(1,2) # 赋值表达式
3、函数调用可以当做参数
res=add(add(1,2),10) # 把返回值当参数
print(res)
(三)函数返回值
return是函数结束的标志,即函数体代码一旦运行到return会立刻
终止函数的运行,并且会将return后的值当做本次运行的结果返回:
1、返回None:函数体内没有return
return
return None
2、返回一个值:return 值
def func():
return 10
res=func()
print(res) # 10
3、返回多个值:用逗号分隔开多个值,会被return返回成元组
def func():
return 10, 'aa', [1, 2]
res = func()
print(res, type(res)) #(10, 'aa', [1, 2]) <class 'tuple'>