十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
sys.path是一个list,存放了当前所有import搜索的路径。
成都创新互联是工信部颁发资质IDC服务器商,为用户提供优质的成都机柜租用服务
绝大多数情况下,首个元素是"",即空串,也就是说,当你import re的时候,首先搜索的是"re",这时候就会直接在当前目录搜索到re。如下图:
解决方法也有不止一个:
1,在当前目录创建一个子文件夹,例如mine,在mine里放一个__init__.py,不用有代码,空文件即可。使用的时候:import mine.re
2,在sys.path上做手脚,把第一个空串挪到最后面去:
import sys
sys.path = sys.path[1:]
sys.path.append("")
这样当前目录会跑到最后面去,从而达到最后搜索的目的。
不过这很可能有副作用,即你创建的模块,不能和前面搜索路径里的任何文件重名,否则会无法import你的模块。
这也是为什么默认把当前路径放在最前搜索的原因,因为是用户自己写的,显然优先级最高。
尽管就你的问题作出分析和提出一些可能的解决办法,但是严重不建议在实际工程起和系统模块重名的文件名,这是自找麻烦。
当然,研究探讨它的实现原理,始终是值得肯定的。
最后强调一下,当你在当前文件夹创建了一个sys.py时,方法2不好用!
Python中from urllib import request和import urlib.request的区别:
Python
from urllib import request
# access request directly.
mine = request()
import urllib.request
# used as urllib.request
mine = urllib.request()
它们实际上是没有区别的,调用的时候有时候为了方便用上面的第一种方式。
Python里import * 是什么意思?
import adsl,那么代码中调用的时候都是adsl.open()之类的,比如调用adsl中的foo函数(举个栗子):adsl.foo()
而from adsl import * ,可以直接用foo()。
class SMineCtrl(Structure): pass
ctrlData=SMineCtrl()
这样可以,你那样些不行,类装载器需要解析完这个类的所有代码行才会创建类对象,在解析到类里面的代码行时还没有这个类对象存在,无法创建这个对象的实例