使用XML解析GBK编码格式的xml文件时,会报错 ValueError: multi-byte encodings are not supported
Robotframework中的代码
${xml} parse xml ${localPath}${/}${filename} strip_namespaces=True
网上查了下,是因为默认的python的xml解析库只支持utf-8的编码格式,有两种方式解决:
1. 把python升级到3.0以上版本
2. 你自己做编码转换 xml.decode('gbk').encode('utf8')
后面看了下RF的XML库的源码,发现它底层可以使用lxml这个库来解析,使用这个库功能会更加强大,但默认是没有打开的。
1. 加载XML库的时候,需要指定使用lxml库,关键是后面的参数 True
*** Settings ***
Documentation 注意:需要安装lxml模块来支持读取不是utf-8编码的xml文件
Library XML True
2. 安装lmxl库 pip install lmxl