今天在做一个项目的时候卡在模块导入这个点上了。赶紧回头总结一下

一.被导入的文件和工作的脚本在一个目录下

1.导入一个.py文件里的功能或参数(导入模块)

先看一下目录结构:

module里有两个功能,一个参数,我们要把module里的内容导入到test里(图里的model拼写错误,请忽略~~)

data = 'in the test'
def fun1():
print('in the test fun1')
def fun2():
print('in the test fun2')

module1

有下面这几种方法:

方法1:

import module1
module1.fun1()
module1.fun2()
print(module1.data)

这种方法直接导入了module.py这个文件,然后直接调用里面的参数。相当于在test.py里加了个名字为module1的变量,把原有module1里的内容赋值给这个变量。然后再调用

如果只需导入fun1,可以用方法2

from module1 import fun1
fun1()

这种只导入了fun1一个功能,但调用的时候不用加上前面的模块名作为前缀,用from...import的语法也可以导入模块下所有的功能

from module1 import *
fun1() #不用加模块名,直接调用
fun2()

这个方法相当于把module里的内容直接复制了一遍在test.py内。但是一般情况下是不要用这个语句,因为可能会造成变量的污染:如果原先有个变量或函数名字和导入模块的名字一样,就会被最后出现的覆盖掉

def fun1():
print('in test fun1')
from module1 import *
fun1()

由于module1内有个函数名为fun1,运行以后,打印出的就成,了

in the test fun1

所以常规情况下一定不要用这个方法。单是如果被导入的模块确实和脚本里的变量名称出现冲突,但是两者又都不能更改,可以用这个方法

def fun1():
print('in test fun1')
from module1 import fun1 as fun
fun()
fun1()

运行一下,工作正常

in the test fun1
in test fun1

2.导入包

如果想导入一个包,其实就是导入了包所在目录下的__init__.py这个文件,

我们重新定义下目录结构

fun1和fun2里都定义了个fun

def fun():
print('in fun1 fun')

fun1

def fun():
print('in fun2 fun')

fun2

修改一下__init__.py这个文件,加一句

print('in the module_test2 __init__.py')

然后直接把包导入到test.py中,运行一下,看看发现了什么?

import module_test2
in the module_test2 __init__.py

可以发现,导入包其实就是执行该包下的__init__.py文件。如果想导入包下的所有文件该怎么操作呢?

from module_test2 import fun1,fun2
fun1.fun()
fun2.fun()

这样就可以导入指定的文件了,其实还有一种方法,我们刚才发现了,导入包的时候就是执行了__init__.py文件,其实也可以把这个文件修改一下,

from . import fun1,fun2   #   一定要加from.

这个from . 一定要加否则默认的路径会错误,在test里导入的时候就成了(相对导入)

import module_test2
module_test2.fun1.fun()
module_test2.fun2.fun()

各有各的好处吧。

ps:我其实就是卡在这里了:是想找一个直接全部导入包的方法,不用把每个文件都输一遍,暂时无解。

二.导入非本目录下的模块

在导入模块的时候,一定要把模块的路径加载sys.path列表里,用sys.path.append将路径加载到环境变量里,如果模块是在工作目录的父目录里,就先获取该模块的地址

import sys,os
dir_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

然后再把它加载到环境变量里

sys.path.append(dir_path)

如果是父目录下的某个子文件夹下的文件夹里,就要把该文件夹的绝对路径加载到sys.path里。

三.导入的优化

1.模块在导入的时候只要模块相同,不管导入了几次只执行一次,所以在导入的时候如果用了这种方式

import test
test.fun1()
test.fun2()

在执行这样的代码时,先加载了test,然后每次调用都是先遍历test,效率相对来说会比较低,可以用from。。。import的方式,直接导入

from test import fun1,fun2
fun1()
fun2()

在调用的时候效率能相对高一点点!

2.由于导入的时候是从前往后遍历sys.path这个列表的,其实为了增加效率,其实不应该用append,而应该用insert,插入列表的第一位,就会增加遍历的速度。

sys.path.append(dir_path)

然后直接用导入包的方法导入就可以了

python之模块的导入的更多相关文章

  1. python与模块的导入方式

    今日所得 模块 import from...import... 循环导入 相对导入 绝对导入 软件开发目录规范 模块 模块:是一系列功能的集合体 模块的三种来源:1.内置模块(Python解释器自带的 ...

  2. 17.python自定义模块的导入方式

    1.直接用import导入 最后运行main.py可以看到命令行窗口输出了一句:你好,这样就完成了. 2.通过sys模块导入自定义模块的路径path 3.在环境变量中找到自定义模块 这个方法原理就是利 ...

  3. python第三方模块的导入

    模块搜索路径 当我们尝试加载一个模块时,Python会在指定的路径下搜索对应的.py文件,如果找不到,就会报错: >>> import module1 Traceback (most ...

  4. python 浅析模块,包及其相关用法

    今天买了一本关于模块的书,说实话,模块真的太多了,小编许多也不知道,要是把模块全讲完,可能得出本书了,所以小编在自己有限的能力范围内在这里浅析一下自己的见解,同时讲讲几个常用的模块. 这里是2018. ...

  5. 万恶之源 - Python 自定义模块

    自定义模块 我们今天来学习一下自定义模块(也就是私人订制),我们要自定义模块,首先就要知道什么是模块啊 一个函数封装一个功能,比如现在有一个软件,不可能将所有程序都写入一个文件,所以咱们应该分文件,组 ...

  6. Python自定义模块

    自定义模块 自定义模块(也就是私人订制),我们要自定义模块,首先就要知道什么是模块 一个函数封装一个功能,比如现在有一个软件,不可能将所有程序都写入一个文件,所以咱们应该分文件,组织结构要好,代码不冗 ...

  7. python模块以及导入出现ImportError: No module named 'xxx'问题

    python中,每个py文件被称之为模块,每个具有__init__.py文件的目录被称为包.只要模块或者包所在的目录在sys.path中,就可以使用import 模块或import 包来使用如果你要使 ...

  8. 浅谈python模块的导入操作

    1.什么是模块 在Python中有一个概念叫做模块(module). 所谓模块,就是将代码量较大的程序分割成多个有组织的,彼此独立但双能互相交互的代码片段, 这些自我包含的有组织的代码段就是模块. 2 ...

  9. python的模块与包的导入

    类似于C语言的包含头文件去引用其他文件的函数,python也有类似的机制,常用的引入方法有以下 import 模块名 #模块名就是py文件名 #使用这种方法以后调用函数的时候要使用模块名.函数名()这 ...

随机推荐

  1. for批处理skip参数不支持变量延迟!n!的解决办法

    a.txt 文件a第1行 文件a第2行 文件a第3行 b.txt 文件b第1行 文件b第2行 文件b第3行 合并ab .bat @echo off REM 把两个文件逐行合并成一列 set n=0 f ...

  2. oracle user_tables没有新创建的表的问题

    oracle 新创建表后,在user_tables没有,在user_tab_columns也没有,暂时未找到办法

  3. Docker三大核心概念及DockerToolBox安装

    一.核心概念 Docker大部分操作都围绕三大概念——镜像.容器和仓库展开. 1.Docker镜像 Docker镜像类似于虚拟机镜像,可以将它理解为一个只读的模板.镜像是创建Docker容器的基础. ...

  4. Java中常用类(包装类扩展知识)

    Java常用类有哪些? 八大基本数据类型的包装类 包装类均位于java.lang包中,包装类和基本数据类型的对应关系如下表: 基本数据类型 包装类 byte Byte boolean Boolean ...

  5. MySQL数据库的库表基本操作

    一.库操作 1.创建业务数据库 DDL 数据库命名规则:区分大小写.唯一性.不能使用关键字如 create select.不能单独使用数字 语法:CREATE DATABASE 数据库名; CREAT ...

  6. [SQL]查询整个数据库中某个特定值所在的表和字段的方法

    查询整个数据库中某个特定值所在的表和字段的方法 当数据库做的太庞大的时候,难免会出现忘记哪个值会存入哪个表的情况,于是在网上找到的如下解决办法. 通过做一个存储过程,只需要传入一个想要查找的值,即可查 ...

  7. Web App Checklist

    Mobile Web App checklist 目标: 高性能Mobile Web App 一.UX和UI 操作节目与边框之间留空隙: 防止操作过程中,触发系统缺省行为,有些是无法disable的. ...

  8. 1816647 - Error "Data file of SAP Note is incomplete" uploading a note in SNOTE

    ymptom When uploading an SAP Note in transaction SNOTE you receive the error "Data file of SAP ...

  9. 关于PS的操作

    1.移动工具 Ctrl+J:拷贝图层 Ctrl+T:自由变换调整大小 Alt+Shift:全选 Ctrl+G:图层编组 Alt+Delete:选中图层填充当前颜色 Ctrl+Alt+Z:后退一步 2. ...

  10. 配置yum源

    本文转载:https://www.cnblogs.com/yangp/p/8506264.html (一)yum源概述 yum需要一个yum库,也就是yum源.默认情况下,CentOS就有一个yum源 ...