Python 模块定义、导入、优化详解
一、定义
- 模块:用来从逻辑上组织 python 代码(变量,函数,类, 逻辑:实现一个功能),本质就是 .py 结尾的 python文件(例如:test.py文件,对应的模块名:test)
- 包:用来从逻辑上组织模块的,本质就是一个目录(必须带有一个 __init__.py 文件)
二、导入方法
# 导入单个模块
import module_name
# 一次导入多个模块
import module1_name,module2_name
# 从module_a模块导入其所有代码
from module_a import *
# 从module_a模块导入多个变量/函数/类
from module_a import m1,m2,m3
# 给logger模块取别名为logger1并导入
from module_a import logger as logger1
# 从当前目录下导入test1模块
from . import test1
三、Import本质(路径搜索和搜索路径)
1. 导入模块的本质就是把python文件解释一遍
- 导入整个模块 = 导入整个模块中全部的代码
import test test = “test.py all code”
- 导入模块中的某个变量或函数 = 只导入该变量或函数,可直接调用
from test import m1 m1 = “code”
- 导入模块(需要先找到)----> 模块对应的python文件 ----> 该python文件的路径 ----> 可用 sys.path 方法获取路径
import module ----> module_name.py ----> module_name.py 的路径 ----> sys.path
2. 导入包的本质就是执行该包下的__init__.py文件
四、同级导入模块
假设,有一个名为 module_test 的目录,该目录下包含一个 module.py 文件和一个 main_module.py 文件。
module.py文件中内容数据如下:
name = 'alex'
def say_hello():
print('hello alex') def logger():
pass
main_module.py 文件中需要调用 module 模块,代码实现如下:
name = 'alex'
def say_hello():
print('hello alex') def logger():
print('in the module')
假如 module 模块中有好几个函数,你想要导入所有的函数,可使用:from module import *
如果当前脚本文件中已经定义了logger()函数,这时要调用的 module.py 文件中又已经包含了一个同名的 logger() 函数,则调用 logger() 函数时会产生冲突,故为了避免冲突,此方法要慎用。
如何避免这种冲突呢?我们可以使用另一种导入方法,即给 logger 函数取别名:from module import logger as logger1
main_module.py 文件代码如下:
# 导入module模块(文件名:module.py,对应的模块名:module)
import module # 调用 module 模块中的变量和函数
print(module.name) # alex
module.say_hello() # hello alex # 定义 logger() 函数
def logger():
print("in the main_module") # logger() # 调用 logger 函数
# 此时返回”in the main_module“,即该文件中的logger函数覆盖了前面调用 module 模块中的同名函数 # 如何解决这个冲突呢?我们可以使用另一种导入方法,即给 logger 函数取别名:
from module import logger as logger1 # 此时再调用改了别名的logger函数logger1
logger1()
# 打印 module 模块中的 logger()函数的返回结果 ”in the module"
五、不同级导入模块
案例:路径为 day5\module_test\main_module1.py 的 main_module1.py文件导入其父级目录 day5目录下的 module1 模块(即day5\module1.py)
module1.py 文件内容数据如下:
name = 'alex'
def say_hello():
print('hello alex') def logger():
print('in the module1')
main_module1.py 文件中需要调用 module1 模块,代码实现如下:
import sys,os
# print(sys.path) # 打印当前相对路径
# C:\Users\Administrator\PycharmProjects\test\day5\module_test\main_module1.py # dirname作用是返回上级目录名,两层dirname代表返回上上级目录,即返回到了day5目录; os.path.abspath(__file__)是打印当前绝对路径 x = os.path.dirname( os.path.dirname( os.path.abspath(__file__) ) )
# C:\Users\Administrator\PycharmProjects\test\day5 # 添加路径,再导入module1 模块(day5\module1.py)
sys.path.append(x)
import module1
print(module1.name) # alex
module1.say_hello() # hello alex
module1.logger() # in the module1
六、导入优化
假设,有一个名为 module_optimize 的包,该包下包含一个__init__.py 文件和一个主逻辑文件 mo_test.py 。
__init__.py 文件内容如下:
def test():
print('in the __init__')
mo_test.py 文件内容如下:
import __init__ def logger():
__init__.test() # 导入__init__模块下的 test() 函数
print('in the logger') def a():
__init__.test() # 导入__init__模块下的 test() 函数
print("in the a") logger()
a()
可见,logger() 函数和 a() 函数都需要调用到 __init__ 模块下的 test() 函数。这时候,当程序执行的时候,就要重复从 __init__.py 文件中检索 test() 函数,造成程序运行时间的浪费。那么,我们可以如何优化呢?
为了避免重复检索模块而浪费运行时间,我们可以使用 from __init__ import test 方法。具体代码如下:
# 导入模块中指定的函数
from __init__ import test def logger():
test() # 直接调用 test() 函数
print('in the logger') def a():
test() # 直接调用 test() 函数
print("in the a") logger()
a()
- End -
Python 模块定义、导入、优化详解的更多相关文章
- python 模块定义导入
1.定义模块:用来从逻辑上组织python代码(变量.函数.类.逻辑:实现一个功能),本质就是:.py结尾的python文件(文件名:test.py,对应的模块名:test)包:本质就是一个目录(必须 ...
- python_79_模块定义导入优化
''' 1.定义 模块:用来从逻辑上组织python代码(变量,函数,类,逻辑:实现一个功能),本质就是.py结尾的python文件 (文件名:test.py,对应的模块名:test. import ...
- python模块与包的详解
一模块 1.什么是模块? 常见场景:一个模块包含python定义和声明的文件,文件名就是模块名字加上.py的后缀 2.为何要是用模块 如果你退出python解释器然后重新进入,那么你之前定义的函数或者 ...
- 8.模块定义导入优化time datetime内置模块
1.模块(module)的定义:本质就是.py的python文件用来从逻辑上组织python代码(变量\函数\类\逻辑:实现一个功能)包(package)的定义:用来从逻辑上组织模块的,本质就是一个文 ...
- 第10.8节 Python包的导入方式详解
一. 包导入与模块导入的关系 由于包本质上是模块,其实对模块的许多导入方法都适用于包,但由于包的结构与模块有差异,所以二者还是有些区别的: 对包的导入,实际上就是包目录下的__init__.py文件的 ...
- python_80_模块定义导入优化实例
运行结果 __import__作用: 同import语句同样的功能,但__import__是一个函数,并且只接收字符串作为参数,所以它的作用就可想而知了.其实import语句就是调用这 ...
- Python Deque 模块使用详解,python中yield的用法详解
Deque模块是Python标准库collections中的一项. 它提供了两端都可以操作的序列, 这意味着, 你可以在序列前后都执行添加或删除. https://blog.csdn.net/qq_3 ...
- 第7.15节 Python中classmethod定义的类方法详解
第7.15节 Python中classmethod定义的类方法详解 类中的方法,除了实例方法外,还有两种方法,分别是类方法和静态方法.本节介绍类方法的定义和使用. 一. 类方法的定义 在类中定 ...
- Python中的高级数据结构详解
这篇文章主要介绍了Python中的高级数据结构详解,本文讲解了Collection.Array.Heapq.Bisect.Weakref.Copy以及Pprint这些数据结构的用法,需要的朋友可以参考 ...
- Nginx配置项优化详解【转】
(1)nginx运行工作进程个数,一般设置cpu的核心或者核心数x2 如果不了解cpu的核数,可以top命令之后按1看出来,也可以查看/proc/cpuinfo文件 grep ^processor / ...
随机推荐
- ado.net 之 oracle 数据库
ado.net 操作oracle 数据库 跟操作mssql 的原来基本一样.只是使用不同的命名空间而已.下面举几个例子: 一. C#读取oracle数据库的表格 ///ado.net 读取table ...
- springMVC中controller的几种返回类型
==网文1,还不错,感觉比较老旧springMVC中controller的几种返回类型 - CSDN博客http://blog.csdn.net/qq_16071145/article/details ...
- php的phar是什么?
phar 要求5.2以上 前言 最近在看composer,是下载了一个composer.phar,然后放到/usr/local/bin目录下,就可以全局使用composer了,然而并不懂phar是什么 ...
- C#基础零碎知识点摘录
1.类分为静态类个非静态类(实例类) 静态类不能创建对象,使用方法时,直接类名.方法名(),常用的静态类有Console类 实例类:创建对象时通过对象调用类的方法 2.当我们声明一个类成员为静态时,意 ...
- django/python日志logging 的配置以及处理
日志在程序开发中是少不了的,通过日志我们可以分析到错误在什么地方,有什么异常.在生产环境下有很大的用处.在java 开发中通常用 log4j,logback 等三方组件.那么在 django中是怎么处 ...
- js中split 正则表示式 (/[,+]/)
定义和用法 split() 方法用于把一个字符串分割成字符串数组. 语法 stringObject.split(separator,howmany) separator 作为分隔符,separator ...
- 【原创】大叔经验分享(26)hive通过外部表读写elasticsearch数据
hive通过外部表读写elasticsearch数据,和读写hbase数据差不多,差别是需要下载elasticsearch-hadoop-hive-6.6.2.jar,然后使用其中的EsStorage ...
- appJSON["window"]["navigationBarTextStyle"] 字段需为 black 或 white
appJSON["window"]["navigationBarTextStyle"] 字段需为 black 或 white 改动成这个就可以了 &qu ...
- Python学习笔记二
---恢复内容开始--- 一. python几种数据类型的比较. 从以下几个方面比较: 1. 是否可变. 不可变类型:变量的值可以发生变化,id也变了,相当于创建了一个新的对象,所以一修改值,id就变 ...
- Java _类 相关知识
成员变量 java对象的属性就是成员变量,其实成员变量就是指普通的变量,可以设置初始值,也可以不设置.当不设置时,会被设置为默认值.(当成员变量前面有private关键词时,说明定义了一个私有成员) ...