Python - 模块与包

简介: Python - 模块与包

前言


如果你在 51 Testting 上面见到这篇文章,不要以为我是盗版哦!因为那是我投稿的文章

 

模块和包的定义


image.png

模块的定义:任何   *.py   的文件都可以当作模块使用 import 导入

包的定义:包含一个__init__.py和其他模块、其他子包的一个目录

实际项目中,所谓的包和模块分别代表什么,如下:

包就是指 test

模块就是 do_excel.pyhttp_request.pyrun.py

 

导入包的各种方法


image.png

我们以上面这个目录讲解,在 run.py 文件中导入各个包的方式

 

导入单个test包

import test

导入report、log包

# 同时导入,用逗号隔开,墙裂推荐

import report, log


# 分开导入

import report

import log

 

导入单个test包,并起别名

import test as t

导入report、log包,并都起别名

import report as r, log as l

 

导入project包下的old包

import project.old

导入project包下的old包下的test包

# 方式一:链式调用

import project.old.test


# 方式二:from .. import ..

from project.old import test

 

到这里先总结下知识点

import后面跟的包名也是单位变量名(自己取的方便理解)

什么意思?以上面old包下的test包举例

场景:假设我要调用test包下的 test.py 里面的 run() 方法

如果用的是方式一,就得这样写

project.old.test.test.run()

而方式二,则是这样写

test.test.run()

可以看到import后面跟什么“变量”,当你要调用包、模块里面的东西时,你就得先写“变量”再调用包名、模块名

 

我们可以再来看看下面的总结

  • import:完全导入
  • from .. import ..:部分导入(针对性导入)

怎么区分它们的意思捏?我们来看看哈;在根目录下的 test 包下的 run.py 代码如下

#!/usr/bin/env python
# -*- coding: utf-8 -*-
num =1
floats = 2.22
strs = "字符串"
def sum():
    print("我是sum")
class test():
    def test(self):
        print("test class")


假设,在项目中其他文件中想调用 run.py 下的变量、函数名、类名

 

导入其他模块的变量、函数名、类名


方式一:import方式

导入的是 run 模块里面所有内容(包括变量、函数、类名),但是还是得通过 test.run 去链式调用

import test.run
# 调用num变量
print(test.run.num)  # 输出1
# 调用sum方法
print(test.run.sum())  # 输出 我是sum


有些小伙伴就想问,难道我不能指定变量、函数名、类名吗?让我们来试试

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import test.run.num
# 调用num变量
print(test.run.num) 


首先,如果你用的是Pycharm,在import最后的num会报黄,hover上去会提有提示 No module named num

然后,运行下文件会报错如下

Traceback (most recent call last):
  File "F:/test/tests.py", line 5, in <module>
    import test.run.num,test.run.floats
ModuleNotFoundError: No module named 'test.run.num'; 'test.run' is not a package

错误的大概意思就是: test.run.num 不是一个模块名, test.run 不是一个

可以看到import的完全导入意思就是:导入最小单位是模块,而不是变量、函数名、类名

 

方式二:from .. import ..

# from 包名.模块名 import 变量/函数/类名
from test.run import num     
from test.run import sum
from test.run import testss
from test.run import floats
if __name__ == '__main__':
    print(num)    
    print(sum())
    print(testss().test())
    print(floats)


执行结果

1

我是sum

test class

2.22

可以看到from .. import .. 的部分导入意思就是:导入最小单位可以是模块,也可以是变量、函数名、类名

 

导入模块的方法


根据上面讲的知识,如果要导入模块有两种方式,一个就是 import 模块名 一个就是 from 包名import 模块名

 

导入test包下的run模块

# import

import test.run


# from

from run import test

 

导入test包下的run、tests模块

# import

import test.run,test.tests


# from

from run import test,tests

 

特别知识


提问:import 包/模块,包和模块是从哪里导入的?

回答:我们是通过 sys.path 所包含的路径列表你下,按顺序查找的

 

怎么理解?

在Pycharm工程下敲以下代码

import sys

print(sys.path)

 

执行结果

['F:\\moocInterface\\test', 'F:\\moocInterface', 'D:\\PyCharm 2019.3.1\\plugins\\python\\helpers\\pycharm_display', 'D:\\python3.6\\python36.zip', 'D:\\python3.6\\DLLs', 'D:\\python3.6\\lib', 'D:\\python3.6', 'D:\\python3.6\\lib\\site-packages', 'D:\\python3.6\\lib\\site-packages\\django-2.1.5-py3.6.egg', 'D:\\python3.6\\lib\\site-packages\\pytz-2018.9-py3.6.egg', 'D:\\PyCharm 2019.3.1\\plugins\\python\\helpers\\pycharm_matplotlib_backend']

 

可以看到:

  1. 当前文件所在路径是放在第一位
  2. 工程路径放在第二位
  3. Pycharm相关路径放在第三位

我们从系统cmd进入Python解释器敲以下代码,查看结果

>>> import sys

>>> print(sys.path)

 

结果如下

['', 'D:\\python3.6\\python36.zip', 'D:\\python3.6\\DLLs', 'D:\\python3.6\\lib', 'D:\\python3.6', 'D:\\python3.6\\lib\\site-packages', 'D:\\python3.6\\lib\\site-packages\\django-2.1.5-py3.6.egg', 'D:\\python3.6\\lib\\site-packages\\pytz-2018.9-py3.6.egg']

 

结论:

我们在Pycharm下import的包、模块,优先会在工程目录下寻找,找不到才会从Python默认安装路径下找

相关文章
|
4月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
579 7
|
4月前
|
监控 安全 程序员
Python日志模块配置:从print到logging的优雅升级指南
从 `print` 到 `logging` 是 Python 开发的必经之路。`print` 调试简单却难维护,日志混乱、无法分级、缺乏上下文;而 `logging` 支持级别控制、多输出、结构化记录,助力项目可维护性升级。本文详解痛点、优势、迁移方案与最佳实践,助你构建专业日志系统,让程序“有记忆”。
398 0
|
4月前
|
JSON 算法 API
Python中的json模块:从基础到进阶的实用指南
本文深入解析Python内置json模块的使用,涵盖序列化与反序列化核心函数、参数配置、中文处理、自定义对象转换及异常处理,并介绍性能优化与第三方库扩展,助你高效实现JSON数据交互。(238字)
492 4
|
存储 人工智能 运维
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
687 48
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
|
4月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
454 0
|
4月前
|
XML JSON 数据处理
超越JSON:Python结构化数据处理模块全解析
本文深入解析Python中12个核心数据处理模块,涵盖csv、pandas、pickle、shelve、struct、configparser、xml、numpy、array、sqlite3和msgpack,覆盖表格处理、序列化、配置管理、科学计算等六大场景,结合真实案例与决策树,助你高效应对各类数据挑战。(238字)
410 0
|
5月前
|
安全 大数据 程序员
Python operator模块的methodcaller:一行代码搞定对象方法调用的黑科技
`operator.methodcaller`是Python中处理对象方法调用的高效工具,替代冗长Lambda,提升代码可读性与性能。适用于数据过滤、排序、转换等场景,支持参数传递与链式调用,是函数式编程的隐藏利器。
196 4
|
5月前
|
存储 数据库 开发者
Python SQLite模块:轻量级数据库的实战指南
本文深入讲解Python内置sqlite3模块的实战应用,涵盖数据库连接、CRUD操作、事务管理、性能优化及高级特性,结合完整案例,助你快速掌握SQLite在小型项目中的高效使用,是Python开发者必备的轻量级数据库指南。
484 0
|
6月前
|
数据处理 开发工具 开发者
requirement.txt 管理python包依赖
在 Python 项目中,`requirements.txt` 用于记录依赖库及其版本,便于环境复现。本文介绍了多种生成该文件的方法:基础方法使用 `pip freeze`,进阶方法使用 `pipreqs`,专业方法使用 `poetry` 或 `pipenv`,以及手动维护方式。每种方法适用不同场景,涵盖从简单导出到复杂依赖管理,并提供常见问题的解决方案,帮助开发者高效生成精准的依赖列表,确保项目环境一致性。
1980 4
|
人工智能 Python
【02】做一个精美的打飞机小游戏,python开发小游戏-鹰击长空—优雅草央千澈-持续更新-分享源代码和游戏包供游玩-记录完整开发过程-用做好的素材来完善鹰击长空1.0.1版本
【02】做一个精美的打飞机小游戏,python开发小游戏-鹰击长空—优雅草央千澈-持续更新-分享源代码和游戏包供游玩-记录完整开发过程-用做好的素材来完善鹰击长空1.0.1版本
593 7

推荐镜像

更多