Проблемы с питоном 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
Другие вопросы по тегам