目录
with open('a','r+',encoding='utf-8')as f: data=f.read() print(data) data=data.replace('d','m') print(data) f.truncate(0) #截断文件内原内容 f.write(data) #对文件内容的一个修改,注意如果指针在文本内容前面,添加时新内容会覆盖原内容,而不是插入新内容
asdasdasd asmasmasm
with open('a','w+',encoding='utf-8')as f: #但凡w/w+操作都会在此时先清空原内容 f.write('ww') data=f.read() print(data) #写入时指针在最后,所以读不到任何内容
with open('a','a+',encoding='utf-8')as f: f.write('nihao') data=f.read() print(data) #该模式下指针始终在文件末端,想要读内容必须先移动指针
offset代表文件指针的偏移量,单位是字节
# seek() with open('36r.txt', 'rt', encoding='utf-8') as fr: print(f"fr.seek(4, 0): {fr.seek(3, 0)}") # 0相当于文件头开始;1相当于当前文件所在位置;2相当于文件末尾 # fr.seek(0,2) # 切换到文件末尾
fr.seek(4, 0): 3
# tell() with open('36r.txt', 'rt', encoding='utf-8') as fr: fr.seek(4, 0) print(f"fr.tell(): {fr.tell()}")
fr.tell(): 4
只有在模式下的read(n),n代表的是字符个数,除此之外,其他但凡涉及文件指针的都是字节个数
# read() with open('36r.txt', 'rt', encoding='utf-8') as fr: print(f"fr.read(3): {fr.read(3)}")
fr.read(3): sdf
truncate(n)是截断文件,所以文件的打开方式必须可写,但是不能用w或w+等方式打开,因为那样直接清空文件了,所以truncate()要在r+或a或a+等模式下测试效果。它的参照物永远是文件头。并且truncate()不加参数,相当于清空文件。
# truncate() with open('36r.txt', 'r+t', encoding='utf-8') as fr: fr.truncate(3)
将硬盘存放的该文件的内容全部加载到内存,在内存中是可以修改的,修改完毕后,再由内存覆盖到硬盘(word,vim,nodpad++等编辑器)。
import os with open('37r.txt') as fr, \ open('37r_swap.txt', 'w') as fw: data = fr.read() # 全部读入内存,如果文件很大,会很卡 data = data.replace('tank', 'tanksb') # 在内存中完成修改 fw.write(data) # 新文件一次性写入原文件内容 # 删除原文件 os.remove('37r.txt') # 重命名新文件名为原文件名 os.rename('37r_swap.txt', '37r.txt')
将硬盘存放的该文件的内容一行一行地读入内存,修改完毕就写入新文件,最后用新文件覆盖源文件。
import os with open('37r.txt') as fr,\ open('37r_swap.txt', 'w') as fw: # 循环读取文件内容,逐行修改 for line in fr: line = line.replace('jason', 'jasonsb') # 新文件写入原文件修改后内容 fw.write(line) os.remove('37r.txt') os.rename('37r_swap.txt', '37r.txt')
总而言之,修改文件内容的思路为:以读的方式打开原文件,以写的方式打开一个新的文件,把原文件的内容进行修改,然后写入新文件,之后利用os模块的方法,把原文件删除,重命名新文件为原文件名,达到以假乱真的目的。
假设现在你是下水道工,如果你事先准备好你的工具箱,等你接到修理下水道的工作的时候,你直接把你的工具箱拿过去直接使用就行了,而不需要临时准备锤子啥的。
在程序中,函数就是具备某一功能的工具,事先将工具准备好就是函数的定义,遇到应用场景拿来就用就是函数的调用。
如果不使用函数,写程序时将会遇到这三个问题:
先定义函数后调用
定义函数
def 函数名(param1、param2……): """ 函数功能的描述信息 :param1:描述 :param2:描述 :return:返回值 """ code 1 code 2 code 3 ... return 返回值
调用函数
函数名(param1、param2……)
定义函数时参数是函数体接收外部传值的一种媒介,其实就是一个变量名
在函数阶段括号内没有参数,称为无参函数。需要注意的是:定义时无参,意味着调用时也无需传入参数。
如果函数体代码逻辑不需要依赖外部传入的值,必须得定义成无参函数。
def func(): print('hello nick') func() # hello nick
在函数定义阶段括号内有参数,称为有参函数。需要注意的是:定义时有参,意味着调用时也必须传入参数。
如果函数体代码逻辑需要依赖外部传入的值,必须得定义成有参函数。
def sum_self(x, y): """求和""" res = x+y print(res) sum_self(1,2) # 3
当你只知道你需要实现某个功能,但不知道该如何用代码实现时,你可以暂时写个空函数,然后先实现其他的功能。
def func(): pass
函数内部代码经过一些列逻辑处理获得的结果。
def func(): name = 'nick' return name name = func() print(name)
nick
现在有一个需求,比较两个人的月薪,然后想获取月薪较大人的年薪。
如果需要在程序中拿到函数的处理结果做进一步的处理,则需要函数必须要有返回值。
需要注意的是:
# 为什么要有返回值 def max_self(salary_x, salary_y): if salary_x > salary_y: return salary_x else: return salary_y max_salary = max_self(20000, 30000) print(max_salary*12)
360000
第一次将函数其实就讲了函数的调用,但是你不得不再次更新你对函数调用的印象。函数名(…)
即调用函数,会执行函数体代码,直到碰到return或者执行完函数体内所有代码结束。
函数运行完毕所有代码,如果函数体不写return,则会返回none。
def foo(): pass print(foo())
none
使用函数的功能
def max_self(x,y): if x>y: return x else: return y # 1. max_self(1,2) # 2. res = max_self(1,2)*12 # 3. max_self(max_self(20000,30000),40000)
在函数定义阶段括号内定义的参数,称之为形式参数,简称形参,本质就是变量名。
在函数调用阶段括号内传入的参数,称之为实际参数,简称实参,本质就是变量的值。
在函数定义阶段,按照从左到右的顺序依次定义的形参,称之为位置形参。
特点:按照位置定义的形参,都必须被传值,多一个不行,少一个也不行。
在函数调用阶段,按照从左到右的顺序依次定义的实参,称之为位置实参。
特点:按照位置为对应的形参依次传值。
在调用函数时,按照key=value的形式为指定的参数传值,称为关键字实参。
特点:可以打破位置的限制,但仍能为指定的形参赋值。
注意:
func(x, y=2) func(y=2, x) # syntaxerror: positional argument follows keyword argument func(x, x=1) # nameerror: name 'x' is not defined
在定义阶段,就已经被赋值。
特点:在定义阶段就已经被赋值,意味着在调用时可以不用为其赋值。
注意:
m = 10 def foo(x=m): print(x) m = 111 foo() # 10
如对本文有疑问, 点击进行留言回复!!
给Django Admin添加验证码和多次登录尝试限制的实现
网友评论