Проблемы с питоном 3.4 и xmltodict
У меня есть этот скрипт Python:
import xmltodict
with open('file.xml') as fd:
doc = xmltodict.parse(fd.read())
print("Name=" + doc['Data']['form'][0]['@Name'])
print("Time=" + doc['Data']['form'][0]['Period']['@Time'])
print("\tM-1\tM-2\tM-3\tM-4")
load_m1 = doc['Data']['form'][0]['Value'][0]['val'][0]['#text']
load_m2 = doc['Data']['form'][0]['Value'][1]['val'][0]['#text']
load_m3 = doc['Data']['form'][0]['Value'][2]['val'][0]['#text']
load_m4 = doc['Data']['form'][0]['Value'][3]['val'][0]['#text']
memory_m1 = doc['Data']['form'][0]['Value'][0]['val'][1]['#text']
memory_m2 = doc['Data']['form'][0]['Value'][1]['val'][1]['#text']
memory_m3 = doc['Data']['form'][0]['Value'][2]['val'][1]['#text']
memory_m4 = doc['Data']['form'][0]['Value'][3]['val'][1]['#text']
cpu_m1 = doc['Data']['form'][0]['Value'][0]['val'][2]['#text']
cpu_m2 = doc['Data']['form'][0]['Value'][1]['val'][2]['#text']
cpu_m3 = doc['Data']['form'][0]['Value'][2]['val'][2]['#text']
cpu_m4 = doc['Data']['form'][0]['Value'][3]['val'][2]['#text']
task_m1 = doc['Data']['form'][0]['Value'][0]['val'][3]['#text']
task_m2 = doc['Data']['form'][0]['Value'][1]['val'][3]['#text']
task_m3 = doc['Data']['form'][0]['Value'][2]['val'][3]['#text']
task_m4 = doc['Data']['form'][0]['Value'][3]['val'][3]['#text']
print("Load\t" + load_m1 + "\t" + load_m2 + "\t" + load_m3 + "\t"+ load_m4)
print("Memory\t" + memory_m1 + "\t" + memory_m2 + "\t" + memory_m3 + "\t" + memory_m4)
print("CPU\t" + cpu_m1 + "\t" + cpu_m2 + "\t" + cpu_m3 + "\t" + cpu_m4)
print("Task\t" + task_m1 + "\t" + task_m2 + "\t" + task_m3 + "\t" + task_m4 )
Если я запускаю его построчно из консоли python3, нет проблем, но если я сохраню его в файле и запустлю как
$ python3 script.py
он возвращает эту ошибку:
Traceback (most recent call last):
File "/usr/lib/python3.4/site-packages/xmltodict.py", line 5, in <module>
import defusedexpat as expat
ImportError: No module named 'defusedexpat'
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "xml.py", line 1, in <module>
import xmltodict
File "/usr/lib/python3.4/site-packages/xmltodict.py", line 7, in <module>
from xml.parsers import expat
File "/home/script.py", line 3, in <module>
doc = xmltodict.parse(fd.read())
AttributeError: 'module' object has no attribute 'parse'
И если позже я захочу запустить его снова построчно из консоли, это произойдет:
Python 3.4.3 (default, May 5 2015, 17:58:45)
[GCC 4.9.2] on cygwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import xmltodict
Traceback (most recent call last):
File "/usr/lib/python3.4/site-packages/xmltodict.py", line 5, in <module>
import defusedexpat as expat
ImportError: No module named 'defusedexpat'
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python3.4/site-packages/xmltodict.py", line 7, in <module>
from xml.parsers import expat
File "/home/xml.py", line 3, in <module>
doc = xmltodict.parse(fd.read())
AttributeError: 'module' object has no attribute 'parse'
>>>
Я проверил это на Ubuntu и Cygwin. Я установил этот путь: "pip3 install xmltodict" в cygwin и таким образом в Ubuntu: "sudo apt-get install python3-xmltodict"
2 ответа
Прошло достаточно времени, поэтому я чувствую себя нормально, продвигая комментарий @Firefly с самоответом к ответу:
... эта ошибка вызвана названием сценария.
Python находит текущий каталог и импортирует его, когда это необходимо, что приводит к множеству циклических проблем.
Переименоватьxml.py
или любой каталог с именемxml
в текущем каталоге, и эта ошибка исчезнет.
Попробуйте удалить xmltodict
пакет со следующей командой:
sudo pip uninstall xmltodict
или
sudo pip3 uninstall xmltodict
И переустановите с помощью следующей команды.
sudo pip3 install xmltodict