深入理解Python中__init__.py文件

1. 簡介

1.1 模塊(Module)和包(Package)的概念

模塊是程序,任何Python程序都可以作為模塊導入。寫在腳本.py文件中的函數,比如xx.py,可以在另一個模塊或者腳本中通過import xx進行導入。如果要導入xx.py中的函數yy,就寫成from xx import yy。可見模塊可以簡單的理解為一個.py文件。

包就是模塊所在的目錄。和文件夾不同的是,包的根目錄下存在__init__.py。一個文件夾根目錄下存在__init__.py那就會認為該文件夾是Python包,否則那這個文件夾就是一個普通的文件夾。

1.2 __init__.py文件簡介

__init__.py文件的作用是將文件夾變為一個Python的包,Python中每個包中,都有__init__.py文件。通常__init__.py文件為空,但是我們還可以為它增加其他的功能。我們在導入一個包時,實際上是導入瞭它的__init__.py文件。這樣我們可以在__init__.py文件中批量導入我們所需要的模塊,而不再需要一個一個的導入。

2. __init__.py內容寫法

2.1 __init__.py文件內容

以PySolid代碼為例。PySolid包的目錄結構如下:

.
├── grid.py
├── point.py
└── __init__.py

__init__.py內容:

# top-level functions
from pysolid.grid import (
    calc_solid_earth_tides_grid,
    plot_solid_earth_tides_grid,
)
from pysolid.point import (
    TIDES,
    calc_solid_earth_tides_point,
    plot_solid_earth_tides_point,
    plot_power_spectral_density4tides,
)

__all__ = [
    '__version__',
    'calc_solid_earth_tides_grid',
    'plot_solid_earth_tides_grid',
    'TIDES',
    'calc_solid_earth_tides_point',
    'plot_solid_earth_tides_point',
    'plot_power_spectral_density4tides',
]

在這裡插入圖片描述

2.2 __init__.py內容解釋

從grid.py中導入兩個函數:

 calc_solid_earth_tides_grid
 plot_solid_earth_tides_grid

從point.py中導入四個函數:

TIDES,
calc_solid_earth_tides_point
plot_solid_earth_tides_point
plot_power_spectral_density4tides

__init__.py中通過定義__all__變量來控制外部調用者能夠調用的范圍,除瞭以下列表中的函數,其它函數都無法被使用,類似於私有函數或變量。

__all__ = [
    '__version__',
    'calc_solid_earth_tides_grid',
    'plot_solid_earth_tides_grid',
    'TIDES',
    'calc_solid_earth_tides_point',
    'plot_solid_earth_tides_point',
    'plot_power_spectral_density4tides',
]

到此這篇關於深入理解Python中__init__.py文件的文章就介紹到這瞭,更多相關Python中__init__.py內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: