Python IMPORT语句语义
问题描述
我无法理解IMPORT语句及其变体。
假设我使用lxml
模块来抓取网站。
以下示例显示...
from lxml.html import parse
parse( 'http://somesite' )
...Google的Python样式指南更喜欢基本的导入语句,以保留名称空间。
我更愿意这样做,但当我尝试这样做时:
import lxml
lxml.html.parse( 'http://somesite' )
...然后我收到以下错误消息:
AttributeError:‘MODULE’对象没有‘html’属性
有没有人能帮我弄明白这是怎么回事?我更喜欢在它们的名称空间中使用模块,但需要一些帮助来理解其语义。
解决方案
import lxml.html as LH
doc = LH.parse('http://somesite')
lxml.html
是一个模块。当import lxml
时,html
模块不会导入lxml
命名空间。这是开发人员的决定。有些包会自动导入一些模块,有些则不会。在这种情况下,您必须使用import lxml.html
自己导入。
import lxml.html as LH
导入html
模块并将其绑定到当前模块命名空间中的名称LH
。因此,您可以使用LH.parse
访问解析函数。
如果您想深入研究包(如lxml
)何时自动导入模块(如lxml.html
),请打开终端并键入
In [16]: import lxml
In [17]: lxml
Out[17]: <module 'lxml' from '/usr/lib/python2.7/dist-packages/lxml/__init__.pyc'>
这里是lxml
包的__init__.py
文件的路径。
如果你看里面的东西,你会发现里面是空的。因此不会导入子模块。如果您查看Numpy的__init__.py
,您会看到许多代码,其中
import linalg
import fft
import polynomial
import random
import ctypeslib
import ma
这些都是导入numpy
名称空间的子模块。因此,从用户的角度来看,import numpy
会自动为您提供访问numpy.linalg
、numpy.fft
等的权限。
相关文章