python包在哪个文件夹下?

Python014

python包在哪个文件夹下?,第1张

python包默认安装在Libsite-packages路径下。

下面我们就来看一下查看python包安装路径的方法:

1、打印输出该包的__file__属性来查看

2、导入包后直接使用print(包名)语句输出包的路径

更多Python知识请关注Python自学网

在导入文件的时候,Python只搜索当前脚本所在的目录,加载(entry-point)入口脚本运行目录和sys.path中包含的路径例如包的安装地址。所以如果要在当前脚本引用其他文件,除了将文件放在和脚本同一目录下,还有以下几种方法,

1. 将文件所在位置添加到sys.path中

import sys

sys.path.insert(0, '/path/to/application/app/folder') # or sys.path.append('/path/to/application/app/folder')

import file

2. 在文件目录下新建__init__.py文件然后调用文件

from application.app.folder.file import func_name

init.py文件

a).init.py文件的作用

该文件的主要作用使初始化Python包。如果目录下面包含了该文件,Python解释器就会将该目录当做一个包,下一步就可以使用import语句在别的.py脚本中引用该目录下的文件。一个标准Python模块的结构如下所示:

package/

__init__.py

file.py

file2.py

subpackage/

__init__.py

submodule1.py

submodule2.py

b). __init__文件可以为空但可以用来建立对包的需求。一般来说会在该文件中写那些类,函数等需要被导入到包水平,从而可以被方便的引用。比如:如果file.py文件中有一个File类,在init.py文件中啥都没写时引用File类需要这样操作:

from package.file import File

如果在__init__.py文件中将file导入包,那就在包水平可以直接引用File类:

# in your __init__.py

from file import File

# in your script

from package import File

此外,还需要注意的一点是__init__.py文件中的all变量。如果解释器在__init__.py文件中观察到了__all__变量,那么在运行from package import *时就只会引入__all__变量中列出的那些模块。例如:如果想在上述结构的只引入submodule1模块,那么可以在subpackage/__init__.py文件中定义__all__ = ['submodule1'],当引用subpackage时from subpackage import *就只引入了submodule1模块。

3. 将文件所在目录添加到python的环境变量

export PYTHONPATH=$HOME/pathToYourScripts/:$PYTHONPATH

以下为纯手打,下面给几个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的,枉我熬夜给你答题。这种白痴楼主就不配在这里问问题。