Python__init__.py 文件于魔法变量__all__使用讲解

GokuCode 正式写手 2022-08-16 11:40:14

Python__init__.py 文件于魔法变量__all__使用讲解

1. 问题描述

深度理解python的__init__.py 于__all__, 用了这么久python 不知道这两个使用方法那就是不懂python

2. 问题解答

__init__.py 文件的作用是将文件夹变为一个Python模块,我们在导入一个包时,    
实际上是导入了它的__init__.py文件,这样我们可以在__init__.py文件中批量导入我们所需要的模块,  
而不再需要一个一个的导入。

本次演示的目录结构,比如我们有一个项目,项目结构是:
在这里插入图片描述
文件介绍:
allmodule 中的文件都是我们定义的方法,包括所有导入的模块

===========S 文件:figure.py==============
def add():
    print('reduce')
===========E 文件:figure.py==============

===========S 文件:fun1.py==============

def fun11():
    print('fun1.fun1')

def fun12():
    print('fun1.fun2')

# __all__ = ['fun11']
===========E 文件:fun1.py==============

===========S 文件:fun2.py==============

def fun21():
    print('fun2.fun1')

def fun22():
    print('fun2.fun2')

# __all__ = ['fun11']
===========E 文件:fun1.py==============


当我们调用allmoudle中的文件时可以使用这种方法
比如a.py调用

===========S 文件:a.py==============
from allmodule.figure import *
from allmodule.fun1 import *
from allmodule.fun2 import *
import os
import sys
import random 
import urllib

print('------this is a.py------')
add()
fun11()
fun21()
print(os)
print(sys)
print(random)
print(urllib)

===========E 文件:a.py==============

当我们使用__init__.py文件时,这个时候就大不一样了


===========S 文件:__init__.py==============
import os
import sys
import random 
import urllib
from .figure import *
from .fun1 import *
from .fun2 import *

# 当使用from allmodule import * 这里的*就是通过__all__控制的
# 使用变量__all__ 相当于 from allmodule import add, os, sys
# 不适用相当于导入所有模块
# __all__ = ['add','os','sys']
===========E 文件:__init__.py==============


===========S 文件:a.py==============
# 这里相当于就是把allmodule中的__init__.py文件导入*是通过__all__来进行控制,没有__all__时就是导入__init__.py文件中的所有模块
from allmodule import *

print('------this is a.py------')
add()
fun11()
fun21()
print(os)
print(sys)
print(random)
print(urllib)

===========E 文件:a.py==============

 

...全文
164 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

6

社区成员

发帖
与我相关
我的任务
社区描述
好文章,让读者一看就懂。 1. 写,让人一看就懂得好文章。 2. 文章遵循两个规范:标题规范,内容规范 3. 文章遵循三个明白:学明白,写明白,看明白。看不明白就下台
pythonjava后端 个人社区 湖北省·武汉市
社区管理员
  • GokuCode
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

1.现在文章抄袭严重,标题党,软色情的问题日益突出,绝大部分文章说不明白问题,所以特此形成一个原创的原理社区用来撰写一看就懂的文章。
2.希望建立一个优秀的原理文章社区主要有以下几点要求
(1)一看标题就知道讲什么的
(2)一看就明白,看不明白就下台
(3)文章遵循两个规范:标题规范,内容规范(使用统一的模板)
(4)文章遵循三个明白:学明白,写明白,看明白

PS:有人会说,这样太严格了吧。

俗话说“无规矩不方圆”,我们制定规矩也是为了产出好文章:

对于读者:有利于快速掌握知识点提升学习效率

对于作者:有利于提升作者的写作规范,提升自己的研发能力和写作能力,只有自己讲懂的知识,记忆才深刻,才能够真正掌握。

另外:程序员越来越多,大部分都没有写注释的习惯和甚至没有学过语法规范,就拿Python 来说,有多少了解PEP8规范的?大厂中的开发规范有很多,阿里的制定了《阿里巴巴Java开发手册》,因为需要协同,所以我们需要规范,只有规范了,才能有大的进步与提升。

试试用AI创作助手写篇文章吧