您的位置:

pythonimport目录,python import 当前目录

本文目录一览:

python import同级目录报错

pycharm 里的.py文件import 同级目录里的其他.py文件报错,如图

![SKCGMF0J $DWGU)2Q@YRZMF.png

原因:pycharm不会将当前的文件目录自动加入自己PYTHONPATH

解决:将当前的文件目录设置为source root(右键点击工程目录,Mark Directory as- Source Root),然后去File-Settings搜索Python Console确保source root路径已加入 PYTHONPATH

步骤一:

步骤二:

参考:

添加python的import搜索目录

如果我们要添加自己的搜索目录,有两种方法:

一是直接修改sys.path,添加要搜索的目录:

第二种方法是设置环境变量PYTHONPATH,该环境变量的内容会被自动添加到模块搜索路径中。设置方式与设置Path环境变量类似。注意只需要添加你自己的搜索路径,Python自己本身的搜索路径不受影响。

python中import是什么意思?

Python中的import语句是用来调用模块的。

一、module

通常模块为一个文件,直接使用import来导入就好了。可以作为module的文件类型有"py"、".pyo"、"pyc"、"pyd"、"so"、"dll"。

二、package

通常包总是一个目录,可以使用import导入包,或者from + import来导入包中的部分模块。

包目录下为首的一个文件便是_init__py。然后是一些模块文件和子目录,假如子目录中也有_init__py那么它就是这个包的子包了。

优点

简单:Python是一种代表简单主义思想的语言。阅读一个良好的Python程序就感觉像是在读英语一样。它使你能够专注于解决问题而不是去搞明白语言本身。

易学:Python极其容易上手,因为Python有极其简单的说明文档。

易读、易维护:风格清晰划一、强制缩进。

速度快:Python的底层是用C语言写的,很多标准库和第三方库也都是用C写的,运行速度非常快。

免费、开源:Python是FLOSS(自由/开放源码软件)之一。

使用者可以自由地发布这个软件的拷贝、阅读它的源代码、对它做改动、把它的一部分用于新的自由软件中。FLOSS是基于一个团体分享知识的概念。

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的,枉我熬夜给你答题。这种白痴楼主就不配在这里问问题。