How to correctly parse utf-8 xml with ElementTree?

前端 未结 1 1524
忘了有多久
忘了有多久 2020-12-31 05:59

I need help to understand why parsing my xml file* with xml.etree.ElementTree produces the following errors.

*My test xml file contains arabic

相关标签:
1条回答
  • 2020-12-31 06:16

    Leave decoding the bytes to the parser; do not decode first:

    import xml.etree.ElementTree as etree
    with open('utf8_file.xml', 'r') as xml_file:
        xml_tree = etree.parse(xml_file)
    

    An XML file must contain enough information in the first line to handle decoding by the parser. If the header is missing, the parser must assume UTF-8 is used.

    Because it is the XML header that holds this information, it is the responsibility of the parser to do all decoding.

    Your first attempt failed because Python was trying to encode the Unicode values again so that the parser could handle byte strings as it expected. The second attempt failed because etree.tostring() expects a parsed tree as first argument, not a unicode string.

    0 讨论(0)
自定义标题
段落格式
字体
字号
代码语言
提交回复
热议问题