特に明記されていない限り、以下は Python3 に基づいています
概要
コードの再利用とより良いメンテナンスのために、Python
モジュールとパッケージが使用されます。Python
ファイルはモジュールであり、パッケージはモジュール (__init__.py
ファイルを含む) を編成する特別なディレクトリです。 Python
使用了模块与包;一个Python
文件就是一个模块,包是组织模块的特殊目录(包含__init__.py
文件)。
模块搜索路径,Python
解释器在特定的目录中搜索模块,运行时sys.path
即搜索路径。
使用import
关键字导入模块,注意 import *
与__all__
的关系。
A module is a file containing Python definitions and statements
Python
模块就是包含定义以及语句的文件,文件名是模块的名字加上.py
后缀。
假设有一个完成特定功能,很好用的函数或者类。为了使用这个功能,不得不把这段代码复制到需要使用的每一个文件中。重复代码是编程的大忌,如果功能实现需要修改,会不得不修改每一个出现的地方,这是反人类的。
重用能够很好的解决这一问题,实际上,函数,类等结构在一定程度上也为重用提供了便利。
Python
中,将一系列相关的函数,类等组织在一个文件中,每一个文件都是一个Python
模块。
使用import
关键字导入模块(模块需在搜索路径中):
import sys;基础导入语句。
import sys as system;为导入的名字起别名。
from sys import path;导入模块特定元素。
from sys import *;从sys中导入全部可导入名字
import-only-once
模块只导入一次这种行为在大多数情况下是一种实质性的优化,在同一个解释器生命周期内,多次使用import
语句导入同一个模块,导入只发生一次。
这一点可以在模块中加入输出语句证明。
import *
与__all__
使用import *
可能会污染当前模块的名字空间,导入了一些不需要引用的名字。因此不推荐使用。
事实上,规范的第三方模块会提供一个模块公共接口,暴露该模块可用的接口。公共接口由模块名为__all__
的列表定义。
如定义名为mtest1
的模块:
__all__ = ['test1', 'test12']def test1():print('test1')def test11():print('test11')def test12():print('test12')
使用全部导入的方式:
>>> form mtest1 import *>>> dir()>>> ['__annotations__', '__builtins__', '__doc__', '__loader__','__name__', '__package__', '__spec__', 'test1', 'test12']
可以看到函数test11()
并没有被导入,这就是__all__
的作用了。
为了更好组织模块,将模块分组为包(package)。
从文件系统上看,包就是模块所在目录。为使Python
解释器将其区别普通目录作为包看待,包中必须直接包含一个名为__init__.py
的文件(模块)。
包基本上就是另外一类模块,不同的地方在于包能包含其他模块与包。包作为一个模块,其内容其实就是文件__init__.py
(模块)的内容。
如名为constants
的包,文件constants/__init__.py
如下:
PI = 3.14
那么可以将包constants
作为普通模块对待:
import constantsprint(constants.PI)
如果要构建一个名为drawing
的包,其中包含shapes
和colors
import キーワードを使用してモジュールをインポートし、import * と __all__ の関係に注意してください。 |
1. モジュールとインポート |
---|---|
Python モジュールは定義とステートメントを含むファイルです。 name モジュールの名前に接尾辞 .py を加えたものです。 |
特定の機能を実行し、使いやすい関数またはクラスがあるとします。この機能を使用するには、このコードを使用する必要があるすべてのファイルにコピーする必要があります。重複したコードはプログラミングではタブーです。関数の実装を変更する必要がある場合、すべてのコードを変更する必要があります。これは人間に反します。 |
Python では、一連の関連する関数、クラスなどが 1 つのファイルにまとめられています。各ファイルは Python モジュールです。 |
import キーワードを使用してモジュールをインポートします (モジュールは検索パスにある必要があります): |
import sys; 基本的なインポート ステートメント。 | import sys as system; インポートされた名前のエイリアス。 |
sys インポート パスから、モジュール固有の要素をインポートします。 | from sys import *;インポート可能な名前をすべて sys からインポートします |
import-only-once |
これは、出力ステートメントをモジュールに追加することで証明できます。 |
import *
と __all__
🎜import *
を使用すると、現在のモジュールの名前空間が汚染され、不要な名前がインポートされる可能性があります参照の。したがって、その使用はお勧めできません。 🎜🎜実際、標準化されたサードパーティ モジュールはモジュールのパブリック インターフェイスを提供し、モジュールで利用可能なインターフェイスを公開します。パブリック インターフェイスは、__all__
という名前のモジュールのリストによって定義されます。 🎜🎜たとえば、mtest1
という名前のモジュールを定義します: 🎜__all__ = ['colors']
test11()
がインポートされていないことがわかります。これは __all__
の役割です。 🎜🎜2. パッケージとその構造🎜🎜 モジュールをより適切に整理するために、モジュールはパッケージにグループ化されます。 🎜Python
インタープリターがパッケージとして扱うには、パッケージに __init__.py
という名前のファイル (モジュール) が直接含まれている必要があります。 🎜🎜パッケージは基本的に別のタイプのモジュールです。違いは、パッケージに他のモジュールやパッケージを含めることができることです。モジュールとして、パッケージのコンテンツは実際にはファイル __init__.py
(モジュール) のコンテンツです。 🎜🎜たとえば、constants
という名前のパッケージの場合、ファイル constants/__init__.py
は次のようになります: 🎜定数
になります: 🎜drawing code> パッケージという名前のモジュールには、<code>shapes
モジュールと colors
モジュールが含まれているため、次のディレクトリとファイルを作成する必要があります: 🎜🎜🎜🎜🎜ファイル/Directory🎜🎜Description🎜🎜🎜🎜🎜🎜 ~/python🎜🎜検索パスに追加されたディレクトリ🎜🎜🎜🎜~/python/drawing🎜🎜パッケージディレクトリ(描画パッケージ)🎜🎜🎜🎜~/python/drawing/__init __ .py🎜🎜パッケージコード (描画モジュール) 🎜🎜🎜🎜~/python/drawing/colors.py🎜🎜color module🎜🎜🎜🎜~/python/drawing/shapes.py🎜🎜shapes module🎜🎜🎜🎜假设已经将~/python
作为搜索目录。依照这个设置,下列导入语句都是合法的:
import drawing
# 导入drawing包(即__init__.py
模块)
import drawing.colors
# 导入colors模块,使用drawing.colors.attr的方式引用
from drawing import shapes
# 导入shapes模块
__all__
变量
与模块的__all__
变量相似,包的__all__
变量决定了使用from package import *
导入的子模块。
如以上drawing
包的__init__.py
文件内容如下:
__all__ = ['colors']
那么使用from drawing import *
只会导入colors
模块。
现在已经编写完了一个很好用的模块,并且通过了测试。那么如何让这个模块可用呢?即如何让这个模块具备可导入到其他模块的能力。
当使用import
语句导入模块时,Python
解释器通过以下方式搜索模块:
首先搜索built-in
模块
最后搜索变量sys.path
提供的路径列表
sys.path
在解释器启动时从以下位置初始化:
当前脚本路径
环境变量PYTHONPATH
指定的路径集合
安装默认路径
sys.path
初始化完成后,可以在运行时修改。
那么现在若要使模块可用,一是将其放置到已有的搜索路径下,二是指定模块所在路径为搜索路径。
一般情况下,若选择第一种方式,我们将模块放置到Python
安装路径的\lib\site-packages
下,这个目录是专门用来安装第三方模块的。正如该目录下的README
文件展示的那样:
This directory exists so that 3rd party packages can be installed here. Read the source for site.py for more details.
若选择第二种方式,直接将模块所在目录加入到环境变量PYTHONPATH
中即可。
值得注意的是,可以在\lib\site-packages
路径下新建一个名为user_lib.pth
的文件,内容是需要搜索的路径,一行一个,也可以将指定路径加入到搜索目录中:
以上がPythonの基礎~パッケージとモジュールを詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。