内容回顾
x+
b
1、读写都是以bytes
2、针对所有文件
3、一定不能指定encoding
with open('a.txt',mode='rb') as f:
res=f.read()
print(res) # bytes类型
res.decode('utf-8')
bytes=>二进制
得到bytes类型的三种方式
1、字符串编码之后的结果
'上'.encode('utf-8')
bytes('上',encoding='utf-8')
2、b'必须是纯英文字符'
3、b模式下打开文件,f.read()读出的内容
f.readline()
f.readlines() & f.read()
with open('a.txt',mode='rt',encoding='utf-8') as f:
for line in f:
print(line)
while True:
# line=f.read(1024)
line=f.readline()
print(line)
if len(line) == 0:
break
#f.seek(10,0)
#f.seek(2,0)
#f.seek(3,0)
# f.seek(10,1)
# f.seek(2,1) # 12
# f.seek(3,1) # 15
f.seek(-3,2)
f.seek(-2,2)
f.seek(-10,2)
rb r+b
今日内容
1、f.seek的应用
tail -f access.log程序讲解
2、文件修改的两种方式
3、函数的基本使用
先定义
三种定义方式
后调用
三种调用方式
返回值
三种返回值的形式
4、函数参数
一 形参与实参介绍
二 形参与实参的具体使用
2.1 位置参数
2.2 关键字参数
2.3 默认参数
今日内容详细
seek函数
import time
with open('access.log', mode='rb') as f:
# 1、将指针跳到文件末尾
# f.read() # 错误
f.seek(0, 2)
while True:
line = f.readline()
if len(line) == 0:
time.sleep(0.3)
else:
print(line.decode('utf-8'), end='')
文件修改的两种方式
import os
with open('a.txt', mode='r+t', encoding='utf-8') as f:
f.seek(9, 0)
f.write('<男妇女主任>')
方式一:文本编辑采用的就是这种方式
实现思路:将文件内容发一次性全部读入内存, 然后在内存中修改完毕后再覆盖写回原文件
优点: 在文件修改过程中同一份数据只有一份
缺点: 会过多地占用内存
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)
方式二:边读边修改。借用临时文件
实现思路:以读的方式打开原文件,以写的方式打开一个临时文件,一行行读取原文件内容,修改完后写入临时文件…,删掉原文件,将临时文件重命名原文件名
优点: 不会占用过多的内存
缺点: 在文件修改过程中同一份数据存了两份
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')
f = open('a.txt')
res = f.read()
print(res)
函数的使用
1、什么是函数
函数就相当于具备某一功能的工具
函数的使用必须遵循一个原则:
先定义
后调用
2、为何要用函数
1、组织结构不清晰,可读性差
2、代码冗余
3、可维护性、扩展性差
3、如何用函数
先定义
三种定义方式
后调用
三种调用方式
返回值
三种返回值的形式
一、定义函数
定义函数的语法
def 函数名(参数1,参数2,...):
"""文档描述"""
函数体
return 值
形式一:无参函数
def func():
# x
# print(
print('哈哈哈')
print('哈哈哈')
print('哈哈哈')
定义函数发生的事情
1、申请内存空间保存函数体代码
2、将上述内存地址绑定函数名
3、定义函数不会执行函数体代码,但是会检测函数体语法
调用函数发生的事情
1、通过函数名找到函数的内存地址
2、然后加口号就是在触发函数体代码的执行
print(func)
func()
示范
def foo():
# print(bar)
bar()
print('from foo')
foo()
def bar(): # bar=函数的内存地址
print('from bar')
形式二:有参函数
def func(x, y): # x=1 y=2
print(x, y)
func(1, 2)
形式三:空函数, 函数体代码为pass
def func(x, y):
pass
三种定义方式各用在何处
1、无参函数的应用场景
def interactive():
name = input('username>>: ')
age = input('age>>: ')
gender = input('gender>>: ')
msg = '名字:{} 年龄:{} 性别'.format(name,age,gender)
print(msg)
interactive()
interactive()
interactive()
interactive()
2、有参函数的应用场景
def add(x, y): # 参数-》原材料
# x=20
# y=30
res = x + y
# print(res)
return res # 返回值-》产品
# add(10,2)
res = add(20,30)
print(res)
3、空函数的应用场景
def auth_user():
"""user authentication function"""
pass
def download_file():
"""download file function"""
pass
def upload_file():
"""upload file function"""
pass
def ls():
"""list contents function"""
pass
def cd():
"""change directory"""
pass
二、调用函数
1、语句的形式: 只加括号调用函数
interactive()
add(1, 2)
2、表达式形式:
def add(x, y): # 参数-》原材料
res = x + y
return res # 返回值-》产品
# 赋值表达式
res = add(1,2)
print(res)
# 数学表达式
res = add(1,2)*10
print(res)
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)
3、返回多个值:用逗号分隔开多个值,会被return返回成元组
def func():
return 10, 'aa', [1, 2]
res = func()
print(res, type(res))
作业
# 1、编写文件修改功能,调用函数时,传入三个参数(修改的文件路径,要修改的内容,修改后的内容)既可完成文件的修改
# 2、编写tail工具
# 3、编写登录功能
# 4、编写注册功能
# 5、编写用户认证功能
# 选做题:编写ATM程序实现下述功能,数据来源于文件db.txt
# 1、充值功能:用户输入充值钱数,db.txt中该账号钱数完成修改
# 2、转账功能:用户A向用户B转账1000元,db.txt中完成用户A账号减钱,用户B账号加钱
# 3、提现功能:用户输入提现金额,db.txt中该账号钱数减少
# 4、查询余额功能:输入账号查询余额
# 选做题中的选做题:登录功能
# 用户登录成功后,内存中记录下该状态,上述功能以当前登录状态为准,必须先登录才能操作