答案:在XML结构简单、无嵌套且格式固定时可用正则提取数据,如用re.search(r'(.*?)', xml_data)提取姓名;但存在嵌套、属性、命名空间或格式不规范时应使用ElementTree等专业解析器。
用正则表达式提取 XML 中的数据在某些简单场景下是可行的,但需要清楚其局限性。以下是如何使用以及何时应避免使用的说明。
当 XML 结构非常简单、格式固定且不嵌套时,可以用正则快速提取特定字段。例如,提取
import rexml_data = '
' match = re.search(r' Alice 30(.*?) ', xml_data) if match: print(match.group(1)) # 输出: Alice
类似地,可以提取 age、id 等扁平标签内容。使用非贪婪匹配 (.*?) 可防止跨标签误匹配。
注意事项:
正则不适合处理真实世界中复杂的 XML 数据,以下情况应改用专业解析器(如 Python 的 xml.e
tree.ElementTree、lxml 等):
例如,下面这种结构就很难用正则可靠提取:
The Great Gatsby F. Scott Fitzgerald
此时使用 ElementTree 或 lxml 才是合理选择。
基本上就这些。小工具脚本中临时提取单层数据可以用正则,但凡涉及结构化处理,就该切换到 XML 解析器。不复杂但容易忽略的是:看似简单的 XML,可能随时变得复杂。