一.模块
- 什么是模块
python中一个py文件就是一个模块 - 怎么关联多个模块
方式1:
import 模块名——将指定的模块导入到当前模块中(模块名就是py文件名)
说明:
a.执行import的时候,实质会进入指定的模块对应的py文件中,去执行里面的代码
b.import导入模块的时候,会检测当前模块之前是否已经导入过,如果已经导入过就不再导入
c.通过import去导入一个模块后,可以通过 模块名.全局变量 去使用被导入的模块中的内容
import test1
# 使用test1中的变量
a = test1.test1_a
print('当前模块:', a)
# 调用test1中的函数
test1.test1_func1()
方式2:
from 模块名 import 变量名/函数名——导入模块中指定的变量或者函数
说明:
a.执行到导入模块的语句的时候,还是会先执行指定模块中的所有语句
b.通过from-import导入的时候,导入多次还是只执行依次(查重)
c.使用的时候只能用import后面的变量/函数,而且用的时候不用在前面加模块名
d.import后面可以使用逗号将多个变量或者函数隔开,也可以使用*将模块中所有的全局变量一起导入
from test2 import test2_a, test2_func1
# from test2 import *#同时导入test2中所有的全局变量
# from test2 import test2_a
print('当前模块', test2_a)
test2_func1()
函数——对功能进行封装——获取当前时间对应的代码封装到函数中
模块——对多个功能和多个数据进行封装——将所有和时间相关的函数或者变量封装到一个py文件中
包——对多个模块进行封装——将所有和时间相关的py文件放到一个文件夹下
什么是包:含有init.py文件的文件夹
- 重命名
import 模块名 as 新模块名
from 模块名 import 变量名 as 新变量名
# from test import test1 as test1_1
# print(test1.test1_a)
# print(test1_1.test1_a)
- 包的导入
import 包名——会直接执行包中的init.py文件中的代码
import 包名.模块名——导入指定包中的指定模块
from 包名 import 模块名
from 包名.模块名 import 变量
# import test
# import test.test1
# print(test.test1.test1_a)
# from test import my_test
# print(my_test.aaa)
from test.my_test import aaa
print(aaa)
二.选择性导入
在模块中将不需要其他模块导入和执行的代码写到if __name__ == '__main__':语句中。
这样就可以阻止代码被其他模块执行
原理:每个模块都有一个__name__属性,默认值是模块对应的py文件的名字。
当正在直接执行模块的时候,模块的__name__属性值就会变成'__main__'。
当import模块的时候,执行模块,模块的__name__属性不是'__main__'。
import test1
# print(test1.test1_a)
if __name__ == '__main__':
#写在这儿的代码不会被其他模块执行;声明在这儿的变量也不会被其他模块导入
print('')
三.文件操作
-
数据本地化
将数据以文件的形式,存储到本地磁盘中。
(程序中变量保存的数据都是存到内存中的,当程序运行结束内存中的数据会销毁)
常见的数据本地化方式:二进制文件(包含音频,视频,压缩包等),普通文本文件,json和xml文件,数据库文件等 -
文件操作(读和写)
文件操作的固定步骤:打开文件(新建文件)-文件操作(读和写)-关闭文件 -
打开文件
open(file,mode='r',...,encoding=None)——返回的是被打开的文件对象
说明:
file——字符串;需要打开的文件的路径(可以是绝对路径,也可以是相对路径)
绝对路径(一般不使用):D:/DYF/day11-文件操作/files/ddf.txt
相对路径:(相对当前的py对应的目录)使用斜杠/最好
./ ——当前目录(./可以省略)
aaa.txt或者./aaa.txt
../——当前目录的上层目录
.../——当前目录的上上层目录
mode——打开方式;打开文件后不同的操作,对应的打开方式不一样
'r'——默认值,以读的方式打开文件,读出来的是字符串
'w'——以写(字符串)的方式打开文件
'rb'/'br'——以读的方式打开,读出来的数据是二进制
'wb'/'bw'——以写的方式打开,写二进制数据到文件中
'a'——以写的方式打开,追加(写字符串到文件中)
'+'——以读写的方式打开
encoding——文本文件编码方式,一般赋值为'utf-8'
utf-8——支持中文编码
gbk——不支持中文编码
# open('D:/DYF/day11-文件操作/files/ddf.txt')
#以读的形式打开一个文本文件,保存到变量f中。对f进行操作,就是对被打开的文件进行操作
f = open('files/ddf.txt','r',encoding='utf-8')
- 文件的读操作
文件对象.read()——从文件读写位置开始读到文件结尾(默认就是获取文件中所有的内容)
文件对象.readline()——读一行内容
文件对象.readlines()
#读文件所有的内容
# content = f.read()
# print(content)
#读一行
# content = f.readline()
# print(content)
#将文件中的内容读完,要求一行一行的读
f.readline()
while f.readline():
print(f.readline())
f.readline()
- 文件的写操作
文件对象.write(字符串)——将字符串中的内容写入到文件中(会完全覆盖原文件中的内容)
'w'——完全覆盖
'a'——在原文件的最后添加
# f = open('files/ddf.txt','w',encoding='utf-8')
# f.write('你好马')
- 关闭文件
文件对象.close()——关闭指定的文件
# f.close()
# g = open('D:\DYF\day11-文件操作\files\ddf.txt','r',encoding='utf-8')
# while True:
# content = g.readline()
# print(content)
# if content == '':
# break
# open('aaa.txt')
# open('./aaa.txt')
四.二进制文件的读写
- open方法的另外一种写法:
with open(文件路径,读写方式,encoding=编码方式) as 文件对象:
文件操作
-->打开文件,将文件存在文件对象中。当文件操作完成会自动关闭
with open('files\ddf.txt',encoding='utf-8') as f:
print(f.read())
print(f.closed)
普通的文本文件,也可以以二进制的形式读和写
- 二进制文件的读
只要将读写方式设置为'rb'/'br'就可以了。读出来的数据直接就是二进制数据
注意:二进制操作不能设置编码方式
#二进制文件的读
with open('files/ddf.txt','rb') as f:
content = f.read()
print(content,type(content))
with open('files/61001537857032.jpg','rb') as f:
content = f.read()
print(content)
#二进制文件的写
with open('imge.jpg','wb') as f:
f.write(content)
- 文件不存在
当以读的方式打开一个不存在的文件,会报'FileNotFoundError'
当以写的方式打开一个不存在的文件,不会报错,并且会创建这个文件
# with open('bcbb.txt','r') as f:
# print(f.read())
with open('bbb.txt','w') as f:
pass
五. 文件操作的应用
写一个程序统计当前程序执行的次数。第一次运行程序打印1,第二次运行的时候打印2,依次类推。
指导思想:
1.使用数据的时候去本地文件中取数据
2.数据修改后,将新的数据更新到本地文件中
with open('files/coun.txt', encoding='utf-8') as f:
count = int(f.read())
# print(count)
print('第%d次进入程序' % count)
#让次数加1
count += 1
with open('files/coun.txt', 'w',encoding='utf-8') as f:
#以'w'方式打开,写入的时候只能写字符串
f.write(str(count))
网友评论