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