迭代取值与索引取值的差异
l1 = [11,22,33,44,55]
# 索引取值
print(l1[0]) # 11
print(l1[1]) # 22
print(l1[0]) # 11
# 迭代取值
res = l1.__iter__()
print(res.__next__()) # 11
print(res.__next__()) # 22
print(res.__next__()) # 33
"""
索引取值
优势:可以随意反复的获取任意数据值
劣势:针对无序的容器类型无法取值
迭代取值
优势:提供了一种通用的取值方式
劣势:取值一旦开始就只能往前不能后退、
ps:具体使用哪个需要结合实际情况
"""
模块简介
1.如何理解模块
模块可以看成是一系列功能的结合体
使用模块就相当于拥有了结合体内的所有功能
ps:使用模块编程就相当于站在巨人的肩膀上
2.模块的分类
1.内置模块
解释器自带的 直接就可以使用的模块
eg:import time time.sleep(3)
2.自定义模块
自己写的模块
eg: 注册功能 登录功能
3.第三方模块
别人写的模块 存在于网络上 使用时提前下载即可
eg: 图形识别 图形可视化 语音识别
3.模块的变现形式
1.py文件(py文件也可以称之为是模块文件)
2.含有多个py文件的文件夹(按照模块功能的不同划分不同的文件存储)
3.已被编译为共享库或DLL的c或c++扩展(了解)
4.使用C编写并链接到pyth解释器的内置模块(了解)
导入模块的两种句式
"""
补充说明
以后真正的项目中 所有的py文件名称都是英文
没有所谓的编号和英文
eg:错误的 01.变量的使用
正确的 test01.py
学习模块的时候 模块的文件名称必须使用英文
py文件被当做模块导入的时候不需要考虑后缀
"""
导入模块的句式1 import句式
import md
"""
import md
执行文件就是 02 模块的导入句式.py
被导入文件是 md.py
1.会产生执行文件的名称空间
2.产生被导入文件的名称空间
3.在执行文件中会获取一个模块的名字 通过该名字点的方式就可以使用到被导入文件名称空间中的名字
补充说明
同一个程序反复导入相同的模块 导入语句智慧执行一次
import md 有效
import md 有效
import md 有效
"""
money = 10
print(md.money)
print(money)
def read1():
print('我是执行文件里面的read函数')
md.read2
money = 1000
md.change()
print(money)
print(md.money)
导入模块的句式2 from...import...句式
from md import money # 指名道姓的导入
print(money) # 999
money = '哈哈哈'
print(money) # 哈哈哈
print(read1)
print(md.read1())
from md import money, read1
read1()
"""
1.创建执行文件的名称文件
2.创建被导入文件的名称空间
3.执行被导入文件中的代码 将产生的名字存储到被导入文件的名称空间中
"""
两种导入句式的优缺点
import md
优点:通过md的方式可以使用到模板内所有的名字 并且不会冲突
缺点:md什么都可以点 有时候并不想让所有的名字都能被使用
from md import money, read1
优点:指名道姓的使用制定的名字 并且不需要加模块名前缀
缺点:名字及其容易产生冲突(绑定关系被修改)
补充知识
1.起别名
情况1:多个模块文件名相同(多个人写)
from md import money as md_my
from md1 import money as md1_my
print(md_my)
print(md1_my)
情况2:原有的模块文件名复杂
import mdd as md
2.导入多个名字
import time,sys,os
上述导入方式建议多个模块功能相似才能适应 不相似尽量分开导入
import time
import os
import sys
from md import money,read1,read2
上述导入方式是推荐使用的 因为多个名字出自于一个模块文件
3.全导入
需求:需要使用模块名称空间中有很多名字 并且只能使用from...import句式
from md import * # *表示所有
ps:针对*号的导入还可以控制名字的数量
在模块文件中可以使用__all__ = [字符串的名字]控制*能够获取的名字
循环导入问题
如何理解循环导入
循环导入就是两个文件彼此导彼此
循环导入容易出现报错现象
使用彼此的名字可能是在没有准备好的情况下就使用
如何解决循环导入保存现象
彼此在使用彼此名字之前 先准备好
"""
循环导入将来尽量避免出现
"""
判断文件类型
所有的py文件中都自带一个__name__内置名
当py文件是执行文件的时候__name__的结果是__main__
当py文件是被导入文件的时候__name__的结果是模块名(文件名)
__name__主要用于开发模块的作者测试自己的代码使用
if __name__ == '__main__':
当文件是执行文件的时候才会执行if的子代码
上述判断一般只出现整个程序的启动文件中
ps:在pycharm中可以直接编写main按tab键自动补全
模块的查找顺序
"""
1.先去内存中查找
2.再去内置中查找
3.再去sys.path中查找(程序系统环境变量)
"""
1.导入一个文件 然后在导入过程中删除该文件 发现还可以使用
import md
import time
time.sleep(15)
print(md.money)
2.创建一个跟内置模块名相同的文件名
import time
print(time.time())
from time import name
print(name)
ps:创建模块文件的时候尽量不要与内置模块名冲突
3.导入模块的时候一定要知道谁是执行文件
所有的路径都是参照执行文件来的
import sys
sys.path.append(r'D:/pythonproject/day22/xxx')
import mdd
print(mdd.name)
"""
1.通用的方式
sys.path.append(目标文件所在的路径)
2.利用from...import句式
起始位置一定是执行文件所在的路径
from xxx import mdd
"""
原创文章,作者:wure,如若转载,请注明出处:https://blog.ytso.com/274163.html