python 包和模块间的引入
##############################总结#######################
主要内容:
- 1. 模块
- 2. import
- 3. from xxx import xxx
1.模块
(1)模块的概述
模块就是一个包含了py定义和声明的文件,文件名就是模块的名字.py后缀,我们写的所有的py文件都可以看成是一个模块
我们加载的模块一般分成4哥通常类别
- 使用pyhton编写的py文件
- 已被变异为共享库或者DLL或C或者C++的扩展
- 包好的组模块的包.
- 使用c编写并连接到python解释器的内置模块
(2)模块的使用缘由
使用模块是为了我们写的代码可以重用,不至于把所有的代码都写在一个文件内,当项目规模比较小的时候. 完全可以使用一个py搞定整个项目的开发,但是如果是一个非常庞大的项目,此时就必须要把相关的功能进行分离,方便我们日常维护,以及新项目的开发.
(2)模块的使用
导入模块有2中方式
import 模块
from xxx import xxxx
2.import
创建一个文件yitian
print("片头曲,倚天屠龙........")
main_person_man = "张无忌"
main_person_woman = "赵敏"
bad_person_one = "成昆"
bad_person_two = "周芷若"
def fight_on_light_top():
print(main_person_man, "粉碎了",bad_person_one ,"的阴谋")
def fight_in_shaolin():
print(main_person_man, "粉碎了", bad_person_two, "的阴谋")
打开另一个py文件
import yitian
print(yitian.main_person_man)#使用模块中定义好的名字
print(yitian.bad_person_one) yitian.fight_in_shaolin()#调用模块中的函数
yitian.fight_on_light_top()
此时在这个跑一趟文件中 引入了yitian模块
注: 在Python中模块是不能够重复导入的,当重复导入模块时,系统会根据sys.modules来判断该模块是否已经导入了,如果已经导入,则不会重复导
import sys
print(sys.modules.keys()) # 查看导入的模块.
import yitian # 导入模块. 此时会默认执行该模块中的代码
import yitian # 该模块已经导入过了. 不会重复执行代码
import yitian
import yitian
导入模块(import之后)时候做了什么?
- python解释器会先通过 sys.modules来判断该模块是否已经导入了该模块. 如果已经导入了则不再导入.
- 为导入的模块创立新的名称空间
- 在新创建的名称空间中运行该模块中的代码
- 创建模块的名字,并使用该名称作为该模块在当前模块中引用的名字.
import yitian
print(globals())
#{'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x0000018141DE4A90>,
# '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': 'E:/Python_workspace/day 025/金庸.py', '__cached__': None,
# 'yitian': <module 'yitian' from 'E:\\Python_workspace\\day 025\\yitian.py'>}
注意. 由于模块在导入的时候会创建其自己的名称空间,所以,我们在使用模块中的变量的时候一般是不会产生冲突的
import yitian
main_person_man="萧峰"
def fight_in_shaolin():
print(main_person_man+"大战扫地僧")
print(yitian.main_person_man) #张无忌
print(main_person_man) #萧峰 yitian.fight_in_shaolin() #张无忌粉碎了周芷若的阴谋
fight_in_shaolin() #萧峰大战扫地僧
注意. 在模块中使用global. 我们之前说global表示把全局的内容引入到局部,但是,这个全局指的是py文件,换句句话说. global指向的是模块内部. 并不会改变外部模块的内容
print("片头曲,倚天屠龙........")
main_person_man = "张无忌"
main_person_woman = "赵敏"
bad_person_one = "成昆"
bad_person_two = "周芷若"
def fight_on_light_top():
print(main_person_man+"粉碎了"+bad_person_one+"的阴谋")
def fight_in_shaolin():
global bad_person_two
bad_person_two = "战五渣"
print(main_person_man+"粉碎了"+bad_person_two+"的阴谋")
# 调用方
import yitian
bad_person_two = "宋青书"
yitian.fight_in_shaolin()
print(yitian.bad_person_two) # 战五渣
print(bad_person_two) # 宋青书,并没有改变当前模块中的内容. 所以模块内部的 global只是用于模块内部
特别特别要注意:如果我们在不同的模块中引入了同一个模块. 并且在某一个模块中改变了被引入模块中的全局变量,则其他模块看到的值也跟着边,原因是python的模块只会引入一次,大家共享同一个名称空间
if __name__ == '__main__':
yitian.main_person_man = "灭绝师太" # 此时, 只有从该模块作为⼊口运行的时候才会把main_person_man设置成灭绝师太
print("哇哈哈哈哈哈") # 只有运行该模块才会打印. import的时候是不会执行这里的代码的
我们还可以对导入的模块进行重新命名:
import yitian as yt # 导入yitian. 但是名字被重新命名成了yt. 就好比变量赋值一样. a = 1 b = a
一次可以引入多个模块
import time, random, json, yitian
正确的导入模块的顺序:
- 所有的模块导入都要写在最上面,这是最基本的
- 先引入内置模块
- 再引入扩展模块
- 最后引入你自己定义的模块
3. from xxx import xxx
当一个模块中的内容过多的时候. 我们可以选择性的导入要使用的内容.
from yitian import fight_in_shaolin
fight_in_shaolin()
此时是可以正常运行的. 但是我们省略了之前的模块,函数() 直接函数()就可以执行了, 并且from语句也支持行语句导入多个内容.
from yitian import fight_in_shaolin, fight_on_light_top, main_person_man fight_in_shaolin()
fight_on_light_top()
print(main_person_man)
同样支持as
from yitian import fight_in_shaolin, fight_on_light_top, main_person_man as
big_lao
fight_in_shaolin()
fight_on_light_top()
print(big_lao)
最后. 看一下from的坑,当我们从一个模块中引入一个变量的时候,如果当前文件中出现了重名的变量时. 会覆盖掉模块引入的那个变量.
所以,不要重名 切记. 不要重名! 不仅是变量量名不要重复,我们自己创建的py文件的名字不要和系统内置的模块重名.否则,引入的模块都是python内置的模块. 切记, 切记.
python 包和模块间的引入的更多相关文章
- python 模块间的引入
转载来自: https://www.cnblogs.com/whitemouseV2-0/p/9925344.html https://www.cnblogs.com/whitemouseV2-0/p ...
- python包-logging-hashlib-openpyxl模块-深浅拷贝-04
包 包: # 包是一系列模块文件的结合体,表现形式是文件夹,该文件夹内部通常会包含一个__init__.py文件,本质上还是一个模块 包呢,就是前两篇博客中提到的,模块的四种表现形式中的第三种 # 把 ...
- python 包和模块
一. 模块 使用内置函数vars()可以查看当前环境下有哪些对象(变量.函数.类) from 模块 import *: 不会导入以下划线开头的对象 只会导入__all__中定义了的对象(__all__ ...
- Python 包、模块、函数、变量作用域
Python 项目的组织结构 - 包 -- 模块 --- 类 ---- 函数.变量 Python是利用包和模块来组织一个项目的. 包: 包的物理表现是一个文件夹,但是一个文件夹却不一定是个包, ...
- 关于python包,模块,.pyc文件和文件导入理解
参考文献 一.包 包是一个文件夹,用来存放模块和子包. 包里一般会有一个__init__.py的文件(也可以没有). 包里会有一个__pycache__文件夹,存放.py文件经解释器解释后的中间字节码 ...
- python包与模块
Python基础-包与模块 摘要 为重用以及更好的维护代码,Python使用了模块与包:一个Python文件就是一个模块,包是组织模块的特殊目录(包含__init__.py文件). 模块搜索路径,Py ...
- python包与模块导入
一 .module 通常模块为一个文件,直接使用import来导入就好了.可以作为module的文件类型有".py".".pyo".".pyc&quo ...
- Pycharm 导入 Python 包、模块
1.点击File->settings 2.选择Project Interpreter,点击右边绿色的加号添加包 3.输入你想添加的包名,点击Install Package 4.可以在Pychar ...
- Python(五) 包、模块、函数与变量作用域
一.while循环与使用场景 CONDITION=1 while CONDITION <=5 : CONDITION +=1 print("hello") else: pri ...
随机推荐
- BZOJ2038[2009国家集训队]小Z的袜子(hose)——莫队
题目描述 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命……具体来说,小Z把这N只袜子从1到N编号 ...
- GIL、进/线程池、同/异步、阻/非阻塞
1 GIL:全局解释器锁 GIL本质就是一把互斥锁,是夹在解释器身上的, 同一个进程内的所有线程都需要先抢到GIL锁,才能执行解释器代码 2.GIL的优缺点: 优点: 保证Cpython解释器内存管理 ...
- 对如下字符串(234453)[234]{2324}分析它的括号使用是否正确,括号匹配(Java实现)
我的一种思路是递归: private static String s = "(2344[)]53[234]{2324}"; private static boolean f(int ...
- 【cf842D】Vitya and Strange Lesson(01字典树)
D. Vitya and Strange Lesson 题意 数列里有n个数,m次操作,每次给x,让n个数都异或上x.并输出数列的mex值. 题解 01字典树保存每个节点下面有几个数,然后当前总异或的 ...
- 【BZOJ2324】[ZJOI2011]营救皮卡丘(网络流,费用流)
[BZOJ2324][ZJOI2011]营救皮卡丘(网络流,费用流) 题面 BZOJ 洛谷 题解 如果考虑每个人走的路径,就会很麻烦. 转过来考虑每个人破坏的点集,这样子每个人可以得到一个上升的序列. ...
- [WC2011]最大XOR和路径(贪心+线性基)
题目大意:给一张无向图,求一条1-n的路径,是路径边权的异或和最小. 题解 这道题的思路很妙,首先我们可以随便找出一条从1到n的路径来,然后我们可以选一些环. 其实不管这个环和这条路径有怎样的关系,我 ...
- webpack入门(四)webpack的api 2 module
接着介绍webpack的module. module Options affecting the normal modules (NormalModuleFactory) 这些选项影响普通的模块 m ...
- 洛谷P3185 分裂游戏
解:这个毒瘤...... 我们首先发现每一堆的个数对操作不产生影响,每个操作都是针对单个石子的. 所以等价于每个石子都是一个独立的游戏.把它们异或起来作为sg函数值即可. 单个石子的sg值,直接暴力计 ...
- C++ const 理解
转载自:https://www.cnblogs.com/jiabei521/p/3335676.html 如果函数需要传入一个指针,面试官可能会问是否需要为该指针加上const,把const加在指针不 ...
- 在vue中使用import()来代替require.ensure()实现代码打包分离
最近看到一种router的写法 import Vue from 'vue' import Router from 'vue-router' Vue.use(Router) const login = ...