python基础入门之模块

1|0python基础入门之模块

1|1索引取值与迭代取值的差异

l1 = [11, 22, 33, 44, 55]
1.索引取值
print( l1[2] ) # 33
可以任意位置任意次数取值,不支持无序类型的数据取值。
2.迭代取值
it = iter(l1) # 创建迭代器对象
print(next(it)) # 11
print(next(it))# 22
只能从前往后依次取值无法后退,支持所有类型的数据取值(无序有序)。
ps:两者的使用需要结合实际应用场景

1|2模块简介

1|01、模块的本质

内部具有一定的功能(代码)的py文件

1|02、python模块的表现模式

1.py文件(py文件也可以称之为是模块文件)
2.含有多个py文件的文件夹(按照模块功能的不同划分不同的文件夹存储)
3.已被编译为共享库或DLL的c或C++扩展(了解)
4.使用C编写并链接到python解释器的内置模块(了解)

1|3模块的分类

  • 自定义模块:我们自己写的模块文件
  • 内置模块:python解释器提供的模块
  • 第三方模块:别人写的模块文件

1|4导入模块的两种句式

注意:

  • 一定要搞清楚谁是执行文件,谁是被导入文件

  • 开发项目时py文件的名称一般是纯英文,不会含中文或空格

01 作业讲解.py #不会出现
test.py views.py #出现
  • 导入模块文件不需要填写后缀名
1import句式
想使用 Python 源文件,只需在另一个源文件里执行 import 语句,语法如下:
# import module1[, module2[,... moduleN]
当解释器遇到 import 语句,如果模块在当前的搜索路径就会被导入。
搜索路径是一个解释器会先进行搜索的所有目录的列表。
import a为例研究底层原理
"""
1.先产生执行文件的名称空间
2.执行被导入文件的代码将产生的名字放入被导入文件的名称空间中
3.在执行文件的名称空间中产生一个模块的名字
4.在执行文件中使用该模块名点的方式使用模块名称空间中所有的名字
"""
2from...import...句式
Python的from语句从模块中导入一个指定的部分到当前命名空间中,语法如下:
# from modname import name1[, name2[, ... nameN]]
from a import name,func1为例研究底层原理
"""
1.先产生执行文件的名称空间
2.执行被导入文件的代码将产生的名字放入被导入文件的名称空间中
3.在执行文件的名称空间中产生对应的名字绑定模块名称空间中对应的名字
4.在执行文件中直接使用名字就可以访问名称空间中对应的名字
"""

1|5导入模块的补充说明

1.importfrom...import...两者优缺点
import句式
由于使用模块名称空间中的名字都需要模块名点的方式才可以用,所以不会轻易的被执行文件中的名字替换掉,但是每次使用模块名称空间中的名字都必须使用模块名点才可以。
from...import...句式
指名道姓的导入模块名称空间中需要使用的名字,不需要模块名点,但是容易跟执行文件中名字冲突。
2.重复导入模块
解释器只会导入一次 后续重复的导入语句并不会执行。
3.起别名
import wuyongerciyuan as wy
from wuyongerciyuan import zhangzehonglovezhanghong as zz
from a import name as n,func1 as f1
4.涉及到多个模块导入
import a
import wuyongerciyuan
如果模块功能相似度不高,推荐使用第一种;相似度高可以使用第二种。
import a, wuyongerciyuan

1|6循环导入问题

1|01.循环导入

​ 两个文件之间彼此导入彼此并且相互使用各自名称空间中的名字 极容易报错

1|02.如何解决循环导入问题

  • 确保名字在使用之前就已经准备完毕
  • 我们以后在编写代码的过程中应该尽可能避免出现循环导入

1|7判断文件类型

所有的py文件都可以直接打印__name__对应的值
当py文件是执行文件的时候__name__对应的值是__main__
当py文件是被导入文件的时候__name__对应的值是模块名
if __name__ == '__main__':
print('哈哈哈 我是执行文件 我可以运行这里的子代码')
上述脚本可以用来区分所在py文件内python代码的执行
使用场景
1.模块开发阶段
2.项目启动文件
"""
from a import * *默认是将模块名称空间中所有的名字导入
__all__ = ['名字1', '名字2'] 针对*可以限制拿的名字
"""

1|8模块的查找顺序

1.内存
import aaa
import time
time.sleep(15)
print(aaa.name)
aaa.func1()
2.内置
import time
print(time)
print(time.name)
"""
以后在自定义模块的时候尽量不要与内置模块名冲突
"""
3.执行文件所在的sys.path(系统环境环境)
一定要以执行文件为准!!!
我们可以将模块所在的路径也添加到执行文件的sys.path中即可
import sys
print(sys.path) # 列表
sys.path.append(r'D:\pythonProject03\day17\mymd')
import ccc
print(ccc.name)

1|9

大白话:多个py文件的集合>>>:文件夹
专业:内部含有__init__.py文件的文件夹(python2必须要求 python3无所谓)

__EOF__

本文作者知了了了了
本文链接https://www.cnblogs.com/zhiliaowang/p/16803909.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   知了了了了  阅读(65)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示

喜欢请打赏

扫描二维码打赏

支付宝打赏