跳至正文

Python如何导入自编py文件

标签:

一. 想要实现的效果

  1. 新建文件夹将自编模块集中管理

  2. 可在其它py文件内import 自编模块,像import第三方库一样

二. 实现的方法

步骤1:将编号的模块 *.py放入文件夹,在我计算机中是:F:\OneDrive\PythonPrj\_myFunction

步骤2:新建用户/系统环境变量。

变量名:PYTHONPATH

变量值:文件夹路径

然后就可以实现想要的效果了,以下三种import方式均可。

这样做的原理是,Python解释器会去以下三个位置找import的模块:

  1. 当前文件所在目录
  2. 环境变量PYTHONPATH指定的目录
  3. Python 默认的安装目录

Python中sys.path变量记录了解释器可Import模块的位置,如下图所示:

所以,可通过操作sys.path变量告诉解释器去哪里找模块,代码如下:

sys.path是个列表,这里用append将一个路径加到了列表中,然后此路径下的模块a就能成功导入了。这种方法多写了两行代码,不方便,所以只适合临时用一下。

三. 进阶用法

如果自编的模块多了,或者想给自编模块加上说明文档的话,还是希望将每个自编模块单独存放在一个文件夹,以便于管理维护。像这样:

然后在文件夹(如myPackage1)内存放自编模块。

这时想导入模块就要按照以下写法:

这是一级子文件夹的写法,更多级文件夹可以一直点(.)下去。当然,一般也就会用到一级子文件夹,二级几乎都不会使用。

四. 使用__init__.py控制导入某文件夹时执行的操作

上述的导入方式一次只能导入一个文件夹里的一个模块,如果想控制一次导入文件夹中的所有模块,而不用一个个用点号去点,我们需要用到__init__.py文件

此文件需要与模块在同一目录中,如下图所示,Python中将拥有__init__.py文件的文件夹称为包

每次import myPackage时,__init__.py会自动执行一次,所以也称为包初始化文件。利用这个特性,我们可以在此文件中写一些代码,用来控制导入文件夹myPackage1时的行为。像这样写:

import sys
# 将__init__.py文件所在目录加入Python搜索目录中,否则会提示找不到myModule1
sys.path.append(__file__[:-12])

import myModule1

然后,在其它py文件中导入myPackage1,因为__init__.py文件自动执行,myModule1文件会自动被导入。验证一下:

当然,即使在包初始化文件里写了import 某模块,还是可以用 import myPackage1.myModule 这样的方式来导入。包初始化文件不会对原本的导入方式有任何影响。

另一种写法,可以一次导入包中某模块中定义的函数和属性,像这样写__init__.py文件:

import sys
# 将__init__.py文件所在目录加入Python搜索目录中,否则会提示找不到myModule1
sys.path.append(__file__[:-12])

from myModule1 import *

然后,在其它py文件导入时这么写:

可见,可以直接使用myModule1中的定义的函数了。

总结一下,导入模块的写法与__init__.py的写法需要保持一致,即要么都import 包名,要么都from 包名 import *,这样才可达到想要的效果。


如果本文对你有所帮助,欢迎点赞、转发、收藏、评论让更多人看到,赞赏支持就更好了。

如果对文章内容有疑问,请务必清楚描述问题,留言评论或私信告知我,我看到会回复。


徐晓康的博客持续分享高质量硬件、FPGA与嵌入式知识,软件,工具等内容,欢迎大家关注。

0 0 投票数
文章评分
订阅评论
提醒
0 评论
内联反馈
查看所有评论
0
希望看到您的想法,请您发表评论x
目录