day11-文件操作
0. record
1.容器类数据类型:
列表: 可变,有序
元组: 不可变,有序 x, y =12, 100; x, *num = 12, 33, 45, 23
字典: 可变 无序
集合: 可变,无序: 元素唯一:支持数学集合运算.
- 函数
a. 函数的声明
def 函数名(参数列表:)
函数体
b. 函数的调用
回到函数声明的位置
传参数(使用实参给形参赋值)
执行函数体
确定返回值
回到函数调用的位置.
c. 参数
位置参数,关键字参数
不定长参数:带的优先放后面,不能放没有的前面
d.确定一个函数的返回值
函数调用函数表达式, 就是函数的返回值.
函数调用的表达式 - 就是函数的返回值,
调用函数:1.) 会执行函数体. 2)获取返回值
d. 匿名函数
lambda 参数列表:返回值.
d. 全局变量和局部变量
e.迭代器
a. 迭代器: 容器, 可以同时存储多个数据,取的时候只能一个一个取, 并且取过的数据在容器中就不存在.
b. 生成器: 是迭代器.数据是通过调用函数,获取yeild后面的值而产生的..数据会在获取的时候产生.
调用一个yield关键字的函数,就是创建一个生成器.
1.生成式
格式1:
(表达式 for 变量 in 序列 )
展开:
def func():
for变量 in 序列
yeild表达式
格式2:
(表达式 for 变量 in 序列 if(条件语句)
展开:
def func1():
for 变量 in 序列:
if 条件语句:
yeild 表达式
2. 模块的使用
2.1. 什么是模块
python中一个py文件就是一个模块.
2.2怎么关联多个模块
方式1:
import 模块名 - 将指定的模块中所有的变量导入到当前模块中(模块名就是py文件的文件名)
说明:
a. 执行import的时候, 实质会进入指定的模块对应的py文件中,取执行里面的 代码.
b. 通过import去导入一个模块的时候,会检测当前模块是否导入过,如果已经导入就不再导入,
c. 然后,可以通过 模块名.全局变量 去使用被导入的模块中的内容.
import test1
方式2:
from 模块名 import 变量名/整数名 - 导入模块中指定的变量
说明:
a. 执行到导入模块语句的时候,还是会先执行指定模块中的所有语句.
b. 通过from - import导入的时候,导入多次还是只执行一次(查重).
c. 使用的时候只能用import后面的变量/函数,而且用的时候不用在前面加模块名.
d. import后面可以使用逗号将多个变量或者函数隔开,也可以使用*将模块中所有的全局变量(包括函数)一起导入,
函数 - 对功能进行封装'
模块 - 对多个功能和多个数据进行封装 - 将所有(和时间)相关的函数或者变量放到一个py文件中.
包 - 对多个模块进行封装 - 将所有和时间相关的py文件放到一个文件夹中
什么是包: 含有init.py文件的文件夹.
3. 重命名]mport 模块名 as 新模块名
from 模块名 import 变量名 as 新变量名
4. 包的导入
import.包名 -会直接执行包中init.py文件中的代码
import 包名.模块名 - 导入指定包中的执行模块.
from 包名 import 模块名
from 包名.模块名 import 变量
5.选择性导入
在模建不需要其它
`
原理: 每个模块都有一个name_属性,属性值是模块对应的py文件的名字,
当正在直接执行模块的时候,模块 name属性值就会变成'main'
当import模块的时候, 执行模块,模块的name属性不是'main.
5文件 录入:
5.1. 数据本地化
将数据中保存的数据都是存到内存中的,当程序运行结束时运内存中行会被销毁
5.2.文件操作(读和写)
文件操作的固定步骤: 打开文件(新建文件) - 文件操作(读) - 关闭文件
5.3打开文件
open(file, mode='r',..., encoding=None)
说明:
file - 字符串; 需要打开的文件的路径(可以是绝对路径, 也可以是相对路径)
(一般不使用))绝对路径:
相对路径:(相对当前的py对应的目录):
./ 当前目录(./可以省略) aaa.txt ./aaa.txt
../ 当前列表的上层目录.
.../ 当前目录的上上层目录.
mode - 打开方式,打开文件后不同的操作,对应的打开方式不一样
'r', 默认值, 以读的方式打开文件
'w' - 以写的方式打开文件.
'rb'/'br', - 以读的方式打开,读出来的数据是二进制.
'wb'/'bw' - 以写的方式打开,写二进制数据到文件中
'a' - 以写的方式打开,追加
'+' - 以读写方式打开
encoding - 文件的编码方式, - 一般赋值为 'utf-8'
utf-8 - 支持中文编码
gbk - 不支持中文编码
f = open('files/蓝莲花.txt', 'r', encoding='utf-8')
5.4. 文件的读操作.
文件对象.read() - 从文件读写位置开始读到文件结尾(默认就是获取文件中所有的内容)
文件对象.readline()
f = open('files/蓝莲花.txt', 'r', encoding='utf-8')
content = f.readline()
while content:
print(content)
content = f.readline()
f.close()
5.5 文件的写操作
文件对象.write(字符串) - 将字符串中的内容写入到文件中.
'w' 完全覆盖
'a'在末尾添加
f = open('files/蓝莲花.txt', 'a', encoding='utf-8')
f.write('你好吗?')
5.6 关闭文件
文件对象.close() --- 关闭指定的文件
f.close()
1.open的另外一种写法:
with open(文件路径,读写方式,encoding=编码方式) as 文件对象:
\ 文件操作
with open ('files/蓝莲花.txt', encoding='utf-8') as f:
print(f.read())
print(f.closed) # True
2.二进制文件的读写
只要将读写方式设置为'rb'/'br'就可以了,读出来的数据直接就是二进制数据.
注意:二进制操作不能设置编码方式.
with open('files/蓝莲花.txt', 'rb') as f:
content = f.read()
print(content, type(content))
with open('files/luffy4.jpg', 'rb') as f:
content = f.read()
print(content)
# 二进制文件的写
with open('imge.jpg', 'wb') as f:
f.write(content)
3.文件不存在
当以读的方式打开一个不存在的文件,会报'FileNotFindError'
当以写的方式打开一个不存在的文件,不会报错,并且会创建这个文件
# with open('bbb.txt', 'r') as f:
# print(f.read())
with open('ddd.txt', 'bw') as f:
# print(f.write())
pass
7.文件操作的应用
写一个程序统计当前程序执行的次数。第一次运行程序打印1,第二次运行的时候打印2,以此类推
# count = 1
# print(count)
# count += 1
with open('files/count.txt', encoding='utf-8') as f:
count = int(f.read()) # 读到的是字符串
# print(count)
print('第%d次进入程序' % count)
# 让次数加1
count += 1
with open('files/count.txt', 'w', encoding='utf-8') as f:
# 以'w'方式打开,写入的时候只能写字符串
f.write(str(count))
f.write()