python高级-包(15)
一、引入包
1.1 有2个模块功能有些联系

receiveMsg.py和sendMsg.py都在msg文件夹里面。
1.2、使用import 文件.模块的方式导入
在桌面创建demo.py文件,并把receiveMsg.py和sendMsg.py使用import文件.模块的方式导入demo.py文件。
receive.py模块
def receiveMessage():
print("正在接受消息...")
send.py模块
def sendMessage():
print("正在发送消息...")
demo.py模块
import msg.send
import msg.receive msg.send.sendMessage()
msg.receive.receiveMessage()
运行结果为:
正在发送消息...
正在接受消息...
1.3使用from文件夹import模块的方式导入
demo.py模块
from msg import *
send.sendMessage()
receive.receiveMessage()
运行结果为:
Traceback (most recent call last):
File "C:\Users\Se7eN_HOU\Desktop\deno.py", line 2, in <module>
send.sendMessage()
NameError: name 'send' is not defined
这个时候我们使用msg下面的模块失败,提示我们没有定义模块
1.4、在msg文件夹下创建 _ _init_ _.py 文件

1.5、在_ _init_ _.py文件中写入
__all__ = ["send","receive"]
1.6重新使用from文件夹import模块的方式导入
from msg import *
send.sendMessage()
receive.receiveMessage()
运行结果为:
正在发送消息...
正在接受消息...
总结:
- 包将有联系的模块组织在一起,即放到同一个文件夹下,并且在这个文件夹创建一个名字为__init__.py 文件,那么这个文件夹就称之为包
- 有效避免模块名称冲突问题,让应用组织结构更加清晰
二、_ _init_ _.py文件
- _ _init_ _.py控制着包导入行为
- _ _init_ _.py为空,意味着仅仅把这个包导入,不会导入包中的模块
- 在_ _init_ _.py文件中,定义一个_ _all_ _变量,它控制着from包名import*是导入的模块
- 可以在_ _init_ _.py文件中编写内容,当导入时,这些语句就会被执行
__init__.py模块
__all__ = ["send","receive"]
print("你导入的msg包")
def test():
print("这里是msg包里面的test")
demo.py模块
import msg
msg.test()
运行结果为:
你导入的msg包
这里是msg包里面的test
三、嵌套的包
假定我们的包的例子有如下的目录结构:
A/#包A
__init__.py
a1.py
sub_B/#包B
__init__.py
b1.py
b2.py
sub_C/#包C
__init__.py
c1.py
c2.py
sub_D/#包D
__init__.py
d1.py
d2.py
A是最顶层的包,sub_B等是它的子包,我们可以这样导入子包:
import A.sub_B.b1
你也可使用 from-import 实现不同需求的导入
第一种方法是只导入顶层的子包,然后使用属性点操作符向下引用子包树:
from A import sub_B
sub_b.b2
此外,我们可以还引用更多的子包:
from A.sub_B import b1
事实上,你可以一直沿子包的树状结构导入
在我们上边的目录结构中,我们可以发现很多的 __init__.py 文件。这些是初始化模块,from-import 语句导入子包时需要用到它。 如果没有用到,他们可以是空文件。
四、包发布
1.myModule目录结构体如下:
./
setup.py
__init__.py
test.py
sub_A/
__init__.py
a.py
sub_B/
__init__.py
b.py
2.编辑setup.py文件
py_modules需指明所需包含的py文件
from distutils.core import setup
setup(name = "Se7eN_HOU",version = "1.0",description = "Se7eN_HOU's module",author = "Se7eN_HOU",py_modules = ["sub_A.a","sub_B.b"])
3.构建模块
使用控制台在setup.py文件的同目录下执行python setup.py build
C:\Users\Se7eN_HOU\Desktop\myModule>python setup.py build
running build
running build_py
copying sub_A\a.py -> build\lib\sub_A
copying sub_B\b.py -> build\lib\sub_B C:\Users\Se7eN_HOU\Desktop\myModule>
构建后目录结构:
./
setup.py
__init__.py
test.py
sub_A/
__init__.py
a.py
sub_B/
__init__.py
b.py
build/
lib/
sub_A/
__init__.py
a.py
sub_B/
__init__.py
b.py
4.生成发布压缩包
同目录下执行python setup.py sdist
C:\Users\Se7eN_HOU\Desktop\myModule>python setup.py sdist
running sdist
running check
warning: check: missing required meta-data: url warning: check: missing meta-data: if 'author' supplied, 'author_email' must be supplied too warning: sdist: manifest template 'MANIFEST.in' does not exist (using default file list) warning: sdist: standard file not found: should have one of README, README.txt, README.rst writing manifest file 'MANIFEST'
creating Se7eN_HOU-1.0
creating Se7eN_HOU-1.0\sub_A
creating Se7eN_HOU-1.0\sub_B
making hard links in Se7eN_HOU-1.0...
hard linking setup.py -> Se7eN_HOU-1.0
hard linking sub_A\__init__.py -> Se7eN_HOU-1.0\sub_A
hard linking sub_A\a.py -> Se7eN_HOU-1.0\sub_A
hard linking sub_B\__init__.py -> Se7eN_HOU-1.0\sub_B
hard linking sub_B\b.py -> Se7eN_HOU-1.0\sub_B
creating dist
Creating tar archive
removing 'Se7eN_HOU-1.0' (and everything under it) C:\Users\Se7eN_HOU\Desktop\myModule>
打包后,生成最终发布压缩包Se7eN_HOU-1.0tar.gz,目录结构
./
setup.py
__init__.py
test.py
sub_A/
__init__.py
a.py
sub_B/
__init__.py
b.py
build/
lib/
sub_A/
__init__.py
a.py
sub_B/
__init__.py
b.py
MANIFEST
dist/
Se7eN_HOU-1.0.tar.gz
五、包的安装、使用
1、安装的方式
- 找到模块的压缩包
- 解压
- 进入文件夹
- 执行命令python setup.py install
注意:
- 如果在install的时候,执行目录安装,可以使用python setup.py install –prefix=安装路径
2、模块的引入
在程序中,使用from import 即可完成对安装的模块使用
from 模块名 import 模块名或者*
六、循环导入
1. 什么是循环导⼊
A.py
from B import b
print("这是A模块")
def a():
print("hello a")
b() a()
B.py
from A import a
print("这是B模块")
def b():
print("Hello b")
a() b()
运⾏python a.py
Traceback (most recent call last):
File "C:\Users\Se7eN_HOU\Desktop\A.py", line 1, in <module>
from B import b
File "C:\Users\Se7eN_HOU\Desktop\B.py", line 1, in <module>
from A import a
File "C:\Users\Se7eN_HOU\Desktop\A.py", line 1, in <module>
from B import b
ImportError: cannot import name 'b' from 'B' (C:\Users\Se7eN_HOU\Desktop\B.py)
像这样A里面引用了B,B里面又引用了A,这样就叫做循环引用
2. 怎样避免循环导⼊
- 1. 程序设计上分层,降低耦合
- 2. 导⼊语句放在后⾯需要导⼊时再导⼊,例如放在函数体内导⼊
python高级-包(15)的更多相关文章
- 想拥有自己的Python程序包,你只需15步
来源商业新知网,原标题:15步,你就能拥有自己的Python程序包 全文共 3192 字,预计学习时长 6 分钟 每个软件开发员和数据科学家都难免要做程序包.本文推荐一篇 Python开源程序包的制作 ...
- python高级特性之封包与解包
前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:kwsy PS:如有需要Python学习资料的小伙伴可以加点击下方链接 ...
- python高级之网络编程
python高级之网络编程 本节内容 网络通信概念 socket编程 socket模块一些方法 聊天socket实现 远程执行命令及上传文件 socketserver及其源码分析 1.网络通信概念 说 ...
- Python天天美味(15) - Python正则表达式操作指南(re使用)(转)
http://www.cnblogs.com/coderzh/archive/2008/05/06/1185755.html 简介 Python 自1.5版本起增加了re 模块,它提供 Perl 风格 ...
- 第八篇:python高级之多进程
python高级之多进程 python高级之多进程 本节内容 多进程概念 Process类 进程间通讯 进程同步 进程池 1.多进程概念 multiprocessing is a package ...
- 第七篇: python高级之多线程
21 interest=0.05 22 count=amount+amount*interest 23 24 self.withdraw(count) 25 26 27 def transfer(_f ...
- 第六篇:python高级之网络编程
python高级之网络编程 python高级之网络编程 本节内容 网络通信概念 socket编程 socket模块一些方法 聊天socket实现 远程执行命令及上传文件 socketserver及 ...
- Python高级特性(1):Iterators、Generators和itertools(转)
译文:Python高级特性(1):Iterators.Generators和itertools [译注]:作为一门动态脚本语言,Python 对编程初学者而言很友好,丰富的第三方库能够给使用者带来很大 ...
- 老男孩Python高级全栈开发工程师【真正的全套完整无加密】
点击了解更多Python课程>>> 老男孩Python高级全栈开发工程师[真正的全套完整无加密] 课程大纲 老男孩python全栈,Python 全栈,Python教程,Django ...
随机推荐
- NC 创建表空间数据库
1.首先创建表空间 CREATE SMALLFILE TABLESPACE "NNC_DATA01" LOGGING DATAFILE 'D:\NCOracle\nc633sd\N ...
- Mysql双主互备+keeplived高可用架构(部分)
一.Mysql双主互备+keeplived高可用架构介绍 Mysql主从复制架构可以在很大程度保证Mysql的高可用,在一主多从的架构中还可以利用读写分离将读操作分配到从库中,减轻主库压力.但是在这种 ...
- 1 - IO
IO流第二天 今日内容 字节流 字符流 字节流 在前面的学习过程中,我们一直都是在操作文件或者文件夹,并没有给文件中写任何数据.现在我们就要开始给文件中写数据,或者读取文件中的数据 字节输出流Outp ...
- python基础--------字符串的调用详解(2)
Python 字符串的的调用方法~~~@@@ 17. strip : 去除字符串左右两边指定的字符 18. rstrip : 去除字符串右边指定的字符 19 . lstrip : 去除 ...
- IOS 设置视图半透明子控件不透明
代码处理: UIColor *color = [[UIColor blackColor] colorWithAlphaComponent:0.6]; self.view.backgroundColor ...
- 关于Selenium.common.exceptions.WebDriverException: Message: Invalid locator strategy: css selector 的问题
在执行脚本时报Selenium.common.exceptions.WebDriverException: Message: Invalid locator strategy: css selecto ...
- 阿里云 ECS centos java timer进程异常/混乱......的解决方法
之前就知道timer进程长久运行容易出问题,所以一直对timer进行了很长一段时间的日志监控和数据库记录,大概观察了几个月,没发现过问题....然后就没管理了,数据库记录也没做了,昨天这问题就来了,t ...
- (PMP)解题技巧和典型题目分析(模拟一)
- 实践中 XunSearch(讯搜)的使用教程步骤
XunSearch(讯搜)的使用教程步骤 一.安装编译工具 yum install make gcc g++ gcc-c++ libtool autoconf automake imake mysql ...
- 25.HashTable
在java中有两个类都提供了一个多种用途的hashTable机制,他们都可以将key和value结合起来构成键值对通过put(key,value)方法保存起来,然后通过get(key)方法获取相对应的 ...