您的位置:

python之import路径(python中import用法)

本文目录一览:

python import路径是什么?

以下为纯手打,下面给几个demos:

说明:

modules所在的目录在python里叫package, 下面是一个名为 IsDir的package(实际上就是一个目录), package下面有4个modules(A, B, C, D)和一个__init__.py文件,目录结构如下:

IsDir/A.py B.py C.py D.py __init__.py大体来讲,有两种方法可以调用某目录下(包括递归目录)的modules.

一. __init__.py为空时

1.1 以下为调用moduleA的代码:

#!/usr/bin/env pythonfrom IsDir import AA.say()输出:

This is module A!1.2 如果想调用moduleA,B,C,D呢?

方法1.

#!/usr/bin/env pythonfrom IsDir import Afrom IsDir import Bfrom IsDir import Cfrom IsDir import DA.say()B.say()C.say()D.say()方法2.

#!/usr/bin/env pythonimport IsDir.Aimport IsDir.Bimport IsDir.Cimport IsDir.Dfrom IsDir import *A.say()B.say()C.say()D.say()错误示例1:

#!/usr/bin/env pythonimport IsDir.AA.say()错误示例2:

#!/usr/bin/env pythonfrom IsDir import *A.say()错误的原因:

IsDir/目录下__init__.py 为空时,直接import IsDir.A 或者from IsDir import *是无效的.

从官方文档里可以看到,__init__.py 里没有__all__ = [module1,module2,...]时,

from IsDir import * 只能保证IsDir被imported, 所以此时IsDir里的modules是无法被imported,此时只有如我上面所写的代码所示才能正确执行,否则是错误的。官方解释为:import IsDir.A并无任何意义,只有接着执行from IsDir import *后,import IsDir.A语句里的module A才会被定义,所以完整的调用因改为: 1. import IsDir.A 2. from IsDir import *。二. __init__.py用all=[...]指定该package下可以被imported进去的module

__init__.py里写入如下内容:

% cat IsDir/__init__.py__all__ = ["A","B"]然后使用之:

#!/usr/bin/env pythonfrom IsDir import *A.say()B.say()结果:

% python test.py This is module A!This is module B!错误实例:

#!/usr/bin/env pythonfrom IsDir import *C.say()以上示例之所以错误,是因为C并没有在__all__ = ["A","B"]里制定,由此可见,package IsDir下面的__init__.py里,__all__=[...]具有隔离modules的作用。

补充:

module A, B, C,D里我分别只定义了一个method, 例如,以下为module A的code:

% cat IsDir/A.pydef say(): print "This is module A!"后记:

谢谢这位同学,回答你的问题感觉很有收获,顺便又把python温习了一遍。回头把这些总结贴到我的blog上以上为手写,望采纳,共勉。

=============================================================

老子写了这么多居然采用了另一个简陋的答案,mlgb的,枉我熬夜给你答题。这种白痴楼主就不配在这里问问题。

Python 中的import 机制

解释器 在执行语句时,遵循作用域原则。因为这和作用域有关系, 如果在顶层导入模块,此时它的作用域是全局的;如果在函数内部导入了模块,那它的作用域只是局部的 ,不能被其它函数使用。如果其它函数也要用到这个模块,还需要再次导入比较麻烦。

在用import语句导入模块时最好按照这样的顺序:

绝对路径 就是文件的真正存在的路径,是指从硬盘的根目录(盘符)开始,进行一级级目录指向文件。

相对路径 就是以当前文件为基准进行一级级目录指向被引用的资源文件。

以下是常用的表示当前目录和当前目录的父级目录的标识符

形如from moduleB import ClassB语句,根据Python内部import机制,执行细分步骤:

总结:from moduleB import ClassB有两个过程,先from module,后import ClassB。

当然将moduleA.py语句 from moduleB import ClassB改为:import moduleB,将在第二次执行moduleB.py语句from moduleA import ClassA时报错:ImportError: cannot import name ‘classA’

在一个文件下同时有 init .py文件、和其他模块文件时,该文件夹即看作一个包(package)。包的导入 和模块导入基本一致,只是导入包时,会执行这个 init .py,而不是模块中的语句。

而且,如果只是单纯地导入包【形如:import xxx】,而包的 init .py中有没有明确地的其他初始化操作,则:此包下的模块 是不会被自动导入的。当然该包是会成功导入的,并将包名称放入当前.py的Local命名空间中。

参考文章:

Python中import机制

Python 3.x可能是史上最详解的【导入(import)】

在Python中以绝对路径或者相对路径导入文件的方法

Python的模块引用和查找路径

python import 路径问题 新手

以下为纯手打,下面给几个demos:

说明:

modules所在的目录在python里叫package, 下面是一个名为 IsDir的package(实际上就是一个目录), package下面有4个modules(A, B, C, D)和一个__init__.py文件,目录结构如下:

IsDir/

A.py  B.py  C.py  D.py __init__.py

大体来讲,有两种方法可以调用某目录下(包括递归目录)的modules.

一.  __init__.py为空时

1.1 以下为调用moduleA的代码:

#!/usr/bin/env python

from IsDir import A

A.say()

输出:

This is module A!

1.2 如果想调用moduleA,B,C,D呢?

方法1.

#!/usr/bin/env python

from IsDir import A

from IsDir import B

from IsDir import C

from IsDir import D

A.say()

B.say()

C.say()

D.say()

方法2.

#!/usr/bin/env python

import IsDir.A

import IsDir.B

import IsDir.C

import IsDir.D

from IsDir import *

A.say()

B.say()

C.say()

D.say()

错误示例1:

#!/usr/bin/env python

import IsDir.A

A.say()

错误示例2:

#!/usr/bin/env python

from IsDir import *

A.say()

错误的原因:

IsDir/目录下__init__.py 为空时,直接import IsDir.A 或者from IsDir import *是无效的.

从官方文档里可以看到,__init__.py 里没有__all__ = [module1,module2,...]时,

from IsDir import * 只能保证IsDir被imported,  所以此时IsDir里的modules是无法被imported,

此时只有如我上面所写的代码所示才能正确执行,否则是错误的。官方解释为:import IsDir.A并无任何意义,只有接着执行from IsDir import *后,import IsDir.A语句里的module A才会被定义,所以完整的调用因改为: 1.  import IsDir.A   2. from IsDir import *。

二.   __init__.py用all=[...]指定该package下可以被imported进去的module

__init__.py里写入如下内容:

% cat IsDir/__init__.py

__all__ = ["A","B"]

然后使用之:

#!/usr/bin/env python

from IsDir import *

A.say()

B.say()

结果:

% python test.py 

This is module A!

This is module B!

错误实例:

#!/usr/bin/env python

from IsDir import *

C.say()

以上示例之所以错误,是因为C并没有在__all__ = ["A","B"]里制定,由此可见,package IsDir下面的__init__.py里,__all__=[...]具有隔离modules的作用。

补充:

module A, B, C,D里我分别只定义了一个method, 例如,以下为module A的code:

% cat IsDir/A.py

def say():

  print "This is module A!"

后记:

谢谢这位同学,回答你的问题感觉很有收获,顺便又把python温习了一遍。回头把这些总结贴到我的blog上以上为手写,望采纳,共勉。

=============================================================

老子写了这么多居然采用了另一个简陋的答案,mlgb的,枉我熬夜给你答题。这种白痴楼主就不配在这里问问题。

python import什么意思

是指在当前目录,相对路径下import某个模块。 import 非常规的常见的用法有:

1、在sys.path里加入你要引用的目录,甚至 ../的绝对目录都可以。

2、absolute_import,可以按绝对路径import某个模块, 实际上这个东西好象不起作用。

至于from .XXX import yyy这种用法,在老的代码里还是常见。其实没有必要。因为import 本身就有这个功能。或者是用更直观的方法importlib.import_module(module,parent)这样不容易犯错误。

Random的作用

Random使用之前需要使用Randomize语句进行随机数种子的初始化。RANDOM产生的是伪随机数或者说是用一种复杂的方法计算得到的序列值,因此每次运算时需要一个不同的种子值。种子值不同,得到的序列值也不同。因此也就是真正的随机数了。

RANDOM产生的是伪随机数或者说是用一种复杂的方法计算得到的序列值,因此每次运算时需要一个不同的种子值。种子值不同,得到的序列值也不同。因此也就是真正的随机数了。这也正是RANDOMIZE随机初始化的作用。 VB里用 NEW RANDOM()来表示初始化。