前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >Python中的一个神秘文件:__init__.py 使用讲解

Python中的一个神秘文件:__init__.py 使用讲解

作者头像
读懂原理
发布2022-12-18 16:28:07
发布2022-12-18 16:28:07
3.5K0
举报
文章被收录于专栏:给点知识给点知识

1. 问题描述

深度理解python的__init__.py 文件, 用了这么久python 不知道这个小知识那就是有点小尴尬

小问题:

当我们使用PythonGUI模块tkinter时发现

from tkinter import * 中不包含messagebox这个模块

(呜呜呜,我都使用*了,*不是代表所有???😱)

必须要使用

from tkinter import messagebox

才行,你知道这是为什么?那就请看文章了。

2. 问题解答

2.1 简介

__init__.py 文件的作用

1.说明这个是一个python的文件夹

2.用来导入包。

我们使用

from xxx import *

导入一个包时,实际上是导入了它的__init__.py文件,这样我们可以在__init__.py文件中批量导入我们所需要的模块,而不再需要一个一个的导入,可以节省很多空间

2.2 演示

本次演示的目录结构,比如我们有一个项目,项目结构是:

文件介绍: 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==============

以上产生的问题是什么

  1. 是不是头文件导入模块太多,占用了很多行
  2. 无法控制* 因为*代表所有模块,但是如果我一个文件中有99个方法,我只用到了80个,剩下的19个不想导入,那么我岂不要写80行,因为我用*就会把不想用的19个全部导进去,所以我需要一个一个添加 from xx import xx1 from xx import xx2 from xx import xx3 ……

那么我们能不能尽量缩短这个呢。这个时候__init__.py就派上用场了。 当我们使用__init__.py文件时,这个时候就大不一样了

===========S 文件:__init__.py==============

import os

import sys

import random import urllib

from .figure import *

from .fun1 import *

from .fun2 import *

# 只允许使用 add os sys 等 模块,不写__all__表示本文件中所导入的模块全部都可以被使用

# __all__ = ['add','os','sys']

# 当使用from allmodule import * 这里的*就是通过__all__控制的

# 使用变量__all__ 相当于 from allmodule import add, os, sys

# 不添加__all__时相当于导入所有模块

===========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==============

3.温馨提示

1.注释信息

文中所用的注释,其中=号应该是用#,为了显目所以用了#号

大概意思都是一样的。

解释一下文中用到的注释,一般注释块可以使用

#号一般使用15个,根据个人爱好吧

-------------------------------------------------

S:start 表示开始

中间写对应代码

E:end 表示结束

-------------------------------------------------

###############S 文件:fun1.py###############

pass

###############E 文件:fun1.py###############

2.已经到底了,文章开头那个问题赶紧再回去看看呀。看看会不会了💨💨💨‍☝

💨

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-07-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 给点知识 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 问题描述
  • 2. 问题解答
  • 2.1 简介
  • 3.温馨提示
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档