【Python学习之九】模块

环境
  虚拟机:VMware 10
  Linux版本:CentOS-6.5-x86_64
  客户端:Xshell4
  FTP:Xftp4
  python3.6

一、模块的使用和安装
模块和C语言中的头文件以及Java中的jar包很类似,使用关键字import引入模块。

1、import module1,mudule2...
当解释器遇到import语句,如果模块在当前的搜索路径就会被导入。

2、在调用math模块中的函数时,必须这样引用:模块名.函数名

import math
#print(sqrt(2))#语法报错
print(math.sqrt(2))

3、from…import

如果只需要用到模块中的某个函数,只需要引入该函数即可,此时可以用下面方法实现:
from modname import name1[, name2[, ... nameN]]
from语句让你从模块中导入一个指定的部分到当前命名空间中

示例:要导入模块fib的fibonacci函数:
from fib import fibonacci

4、from modname import *
把一个模块的所有内容全都导入到当前的命名空间。
注意:这提供了一个简单的方法来导入一个模块中的所有项目。然而这种声明不该被过多地使用。

5、定位模块
当你导入一个模块,Python解析器对模块位置的搜索顺序是:
(1)当前目录
(2)如果不在当前目录,Python则搜索在shell变量PYTHONPATH下的每个目录。
(3)如果都找不到,Python会察看默认路径。UNIX下,默认路径一般为/usr/local/lib/python/
(4)模块搜索路径存储在system模块的sys.path变量中。变量里包含当前目录,PYTHONPATH和由安装过程决定的默认目录。

6、安装模块

#安装
conda install 模块
pip install 模块 
#更新
conda update 模块
#卸载
conda remove 模块
#查找
conda search 模块
#列出清单
conda list

 

二、模块制作

1、定义自己的模块
在Python中,每个Python文件都可以作为一个模块,模块的名字就是文件的名字。
示例:

test.py
def add(a,b): 
return a+b 

2、调用自己定义的模块

在其他文件中可以先import test,然后通过test.add(a,b)来调用,当然也可以通过from test import add来引入
示例:

main.py
import test 
result=test.add(11,22) 
print(result)

3、测试模块

在实际开中,当一个开发人员编写完一个模块后,为了让模块能够在项目中达到想要的效果,这个开发人员会自行在py文件中添加一些测试信息,
示例:

test.py
def add(a,b): 
return a+b 
# 用来进行测试 
ret=add(12,22) 
print('int test.py file,,,,12+22=%d'%ret) 

如果此时,在其他py文件中引入了此文件的话,想想看,测试的那段代码是否也会执行呢!

main.py
import test 
result=test.add(11,22) 
print(result)

至此,可发现test.py中的测试代码,应该是单独执行test.py文件时才应该执行的,不应该是其他的文件中引用而执行

为了解决这个问题,python在执行一个文件时有个变量__name__,

__name__标识模块名字的一个系统变量。前后加了双下划线这是系统定义的名字。普通变量不要使用此方式命名变量。

def test():
  print '__name__ = ',__name__
if __name__ == '__main__':
  test()

分两种情况:

(1)假如当前模块是主模块(也就是调用其他模块的模块),那么此模块名字就是__main__,通过if判断这样就可以执行“__mian__:”后面的主函数内容;
(2)假如此模块是被import的,则此模块名字为文件名字(不加后面的.py),通过if判断这样就会跳过“__mian__:”后面的内容。

 

4、模块中的__all__

__all__用于模块公开接口的一种约定,__all__提供了暴露接口用的”白名单“。一些不以下划线开头的变量(比如从其他地方 import 到当前模块的成员)可以同样被排除出去。

import os
import sys

__all__ = ["process_xxx"] # 排除了 `os` 和 `sys`

def process_xxx():
    pass # omit

(1)__all__ 应该是 list 类型的;

(2)不应该动态生成 __all__,比如使用列表解析式。__all__ 的作用就是定义公开接口,如果不以字面量的形式显式写出来,就失去意义了;
(3)即使有了__all__ 也不应该在非临时代码中使用 from xxx import * 语法,或者用元编程手段模拟 Ruby 的自动 import。Python 不像 Ruby,没有 Module 这种成员,模块就是命名空间隔离的执行者。如果打破了这一层,而且引入诸多动态因素,生产环境跑的代码就充满了不确定性,调试也会非常困难;
(4)按照 PEP8 建议的风格,__all__ 应该写在所有 import 语句下面,和函数、常量等模块成员定义的上面。

三、Python中的模块

1、python中的包
包将有联系的模块组织在一起,即放到同一个文件夹下,并且在这个文件夹创建一个名字为__init__.py 文件,那么这个文件夹就称之为包;
有效避免模块名称冲突问题,让应用组织结构更加清晰

(1)包就是一个目录;
(2)把多个py文件放到同一个文件夹下;
(3)使用import 文件夹.模块 的方式导入,python3可以导入包,python2不行。
(4)使用from 文件夹 import 模块 的方式导入,python3可以导入包,python2不行。
(5)在包的文件夹下创建__init__.py文件。
在python2中:有一个目录,并且目录下有一个__init__.py的文件,才叫包。
有__init__.py文件在python3中没有有错,为了兼容python2,以后我们都在包的目录下新建一个__init__.py文件。
(6)在__init__.py文件中写入

from . import 模块1
from . import 模块2

那么可以使用import 文件夹 导入

2、 __init__.py文件有什么用:__init__.py 控制着包的导入行为。
(1)__init__.py为空:仅仅是把这个包导入,不会导入包中的模块;
(2)可以在__init__.py文件中编写内容,可以在这个文件中编写语句,当导入时,这些语句就会被执行;

四、模块的发布、安装、引用
mymodule目录结构体如下:

. 
├── setup.py 
├── suba 
│ ├── aa.py 
│ ├── bb.py 
│ └── __init__.py 
└── subb 
├── cc.py 
├── dd.py 
└── __init__.py

 

1、编辑setup.py文件

from distutils.core import setup 
setup(name="压缩包的名字", version="1.0", description="描述", author="作者", py_modules=['suba.aa', 'suba.bb', 'subb.cc', 'subb.dd'])

注意:py_modules需指明所需包含的py文件

2、构建模块

python setup.py build

3、生成发布压缩包

python setup.py sdist

4、安装

(1)找到模块的压缩包(拷贝到其他地方)
(2)解压
(3)进入文件夹
(4)执行命令

python setup.py install

注意:如果在install的时候,执行目录安装,可以使用

python setup.py install --prefix=安装路径 

 

5、模块的引入

在程序中,使用from import 即可完成对安装的模块使用
from 模块名 import 模块名或者*

 

参考:
Python学习笔记

posted @ 2019-05-06 17:06  cac2020  阅读(262)  评论(0编辑  收藏  举报