py学习之路11---模块与包
来源:互联网 发布:淘宝分销卖家怎么发货 编辑:程序博客网 时间:2024/05/07 17:35
先盗张图_(:зゝ∠)_
模块
py中的模块类似其他语言中的头文件。我们可以把一些主题相关的函数和类放在一个模块里,这为py增加了许多可拓展性。
导入一个模块
我们先来导入一个模块,最开始py有一个内置的模块sys
import sys
我们通过‘.’来访问sys模块里的变量,函数或类。
sys.platform'win32'
sys是system的缩写,其内部储存的往往是系统相关的信息,而其中的platform表示当前的系统平台。
创建一个模块
我们来写一个模块
def p(): print("a")
把上面的代码写入文件A.py中,然后尝试导入它
>>> import ATraceback (most recent call last): File "<pyshell#46>", line 1, in <module> import AImportError: No module named 'A'
很显然,py无法找到被我们’随便’放置的文件。
这是因为py维护了一个默认的目录,py只会在这些目录下查找文件。sys的path变量会告诉我们默认目录的位置:(需要导入sys模块)
>>> print(sys.path)['', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\Lib\\idlelib', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\python35.zip', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\DLLs', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\lib', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\lib\\site-packages']
然后随便选一个目录,把我们的A.py放进去就可以了。
>>> import A>>> A.p()a
我们也可以添加新的默认目录
sys.path.append("C:\\Users\\Administrator\\Desktop")
导入模块中的一部分
我们可以看到在导入模块后,我们要通过模块名来对模块内的东西进行访问,那么如果模块内的某个函数的使用频率非常高的话,每次使用都要多打一个模块名是非常不方便的,好在我们可以把那个函数单独从模块中导出:
>>> from A import p>>> p()a
或者使用*号导入全部
>>> from A import *>>> p()a
导入了模块的一部分后任然可以导入整个模块
>>> from A import p>>> import A>>> p()a>>> a.p()a
导入时为目标重命名
使用as来改变名称:
import A as C
from A import p as print
导入同名函数的情况
有时候在两个模块里会出现两个同名的函数(或变量,类),如果我们先后导入这两个函数,那么后导入的会覆盖先导入的:
写一个新的模块B
def p(): print("b")
使用情况:
>>> from A import p>>> p()a>>> from B import p>>> p()b
包
一般来讲,一个模块通常只储存一个类,那么出现多个相关类的情况时,我们就可以创建一个包来进行管理,包与操作系统的目录结构类似。
创建一个包
首先在py的默认目录下创建一个文件夹kit。然后在kit里创建两个文件A.py和B.py
A.py
def printA(): print("a")
B.py
def printB(): print("b")
然后相当重要的一点,在目录下新建一个__init__.py文件。这个文件提示python这个是一个包目录,当导入包时,__init__文件首先被计算,它指定了要使用的文件及方式:
__init__.py
from .A import *from .A import *
之后在我们的程序里导入kit模块就可以了
>>> import kit>>> kit.printA()a
__all__
之前提到使用from … import 来显式的导入名称。现在我们可以在__init__中决定from … import 所导入的部分。
修改__init__.py
from .A import *from .B import *__all__ = ["printA"]
然后导入kit模块:
>>> from kit import *>>> printA()a>>> printB()Traceback (most recent call last): File "<pyshell#40>", line 1, in <module> printB()NameError: name 'printB' is not defined
虽然通过*号导入了全部,但我们真正能使用的还是只有__all__列表中所保存的函数。
__name__
py中的__name__会告诉我们程序中正在运行的作用域名称。
>>> __name__'__main__'
保留字__main__是顶层全局作用域的名称。
如果我们修改之前kit的__init__文件:
from .A import *from .B import *__all__ = ["printA"]print(__name__)
那么在导入时:
>>> import kitkit
所以
1. 如果模块是被导入,__name__的值为模块名字
2. 如果模块是被直接执行,__name__的值为’__main__’
我们可以在写模块时使用:
if __name__ == '__main__'
来进行测试,如果是在写模块的过程中,那么这句if语句就会被执行,而在模块被调用的过程中就不会执行。
- py学习之路11---模块与包
- py 类,模块, 包与库
- Lua语言学习之模块与包
- Python学习之模块与包
- py学习之路
- python学习笔记(四)之模块与包
- py学习之路10---类与对象
- Python之模块与包
- python之 模块与包
- python模块学习之模块和包
- 我的python学习之路----包、模块
- python学习(2):自定义包结构及__init__.py模块和__all__变量的使用
- Dojo学习笔记(1. 模块与包)
- Dojo学习笔记(1. 模块与包)
- 13.lua学习笔记:模块与包
- Lua学习笔记--模块与包
- Python基础之包与模块
- py学习之路1-字符串
- 3的倍数和5的倍数
- Java里面的StringBuffer剖析
- krpano HTML5 Viewer
- java多线程与高并发的快速入门指南
- java实现快速排序算法
- py学习之路11---模块与包
- 关于const char*和char*、const char** 和char** 赋值问题
- 【数据库】MySQL 5.7 的多源复制
- Git 常用命令
- 【WebScraping】并行下载_多线程爬虫&多进程爬虫
- 三维平台升级
- this is incompatible with sql_mode=only_full_group_by
- MySQL substring:字符串截取
- linux服务器负载高