在学习使用Python解析XML的过程中遇到ImportError:
No module named etree.ElementTree
检查Python的库路径/usr/lib/python2.7/xml/etree,发现xml.etree.Element包是正常的
报错提示是import xml.etree.ElementTree as ET 这一句有问题,
最后求助于百度,搜索了很久,网友们好像都挻顺利的,几乎没人提过有这种情况。
后来,终于在一个不起眼的角落看到了这么一句话:不要用xml 作为文件名。
本人正是把代码文件命名成了xml.py,马上重命名,再运行。结果还是不行,仔细排查,发现生成的xml.pyc文件还存在,有可能是它造成的影响,删了重试,终于顺利运行。
Python引用包的时候应该是先在代码文件所在的文件夹查找,把文件名命名为xml.py时,import xml.etree.Element 这一句就在当前文件夹找到了自身源文件,自己写的xml.py里面根本就没有etree.Element这些模块,当然是要报错了。
检查Python的库路径/usr/lib/python2.7/xml/etree,发现xml.etree.Element包是正常的
报错提示是import xml.etree.ElementTree as ET 这一句有问题,
最后求助于百度,搜索了很久,网友们好像都挻顺利的,几乎没人提过有这种情况。
后来,终于在一个不起眼的角落看到了这么一句话:不要用xml 作为文件名。
本人正是把代码文件命名成了xml.py,马上重命名,再运行。结果还是不行,仔细排查,发现生成的xml.pyc文件还存在,有可能是它造成的影响,删了重试,终于顺利运行。
Python引用包的时候应该是先在代码文件所在的文件夹查找,把文件名命名为xml.py时,import xml.etree.Element 这一句就在当前文件夹找到了自身源文件,自己写的xml.py里面根本就没有etree.Element这些模块,当然是要报错了。
本文介绍了在使用Python进行XML解析时遇到的ImportError问题及其解决办法。问题源于将文件命名为xml.py,导致Python错误地引用了该文件而不是内置的ElementTree模块。通过重命名文件并删除缓存文件最终解决了问题。
414

被折叠的 条评论
为什么被折叠?



