Delphi中TXMLDocument需设Active=True才可用,支持MSXML/OpenXML;可加载文件/字符串/流,解析用DocumentElement遍历,生成节点须用OwnerDocument创建,保存时注意UTF-8编码处理。

Delphi 中使用 TXMLDocument 解析和生成 XML 是常见需求,但要注意它在不同版本中的行为差异(尤其是 Delphi 7 到 XE 系列),以及底层依赖(MSXML 或 OpenXML)。核心在于正确创建、加载、遍历和保存文档。
创建和初始化 TXMLDocument
TXMLDocument 是一个封装类,本身不直接持有 XML 数据,而是代理到底层 DOM 对象。必须显式启用 Active 属性才能使用:
- 设计时:在窗体上拖入
TXMLDocument,将 Active 属性设为 True;或代码中调用XMLDoc.Active := True; - 若需指定解析器(如避免 MSXML 依赖),可设置 DOMVendor 属性,例如:
XMLDoc.DOMVendor := GetDOMVendor('OpenXML');(需引用Xml.XMLDoc和Xml.xmldom) - 新建空文档:调用
XMLDoc.LoadFromXML('<?xml version="1.0"?><root></root>');或先XMLDoc.Active := False;再XMLDoc.XML.Text := '<?xml version="1.0"?><root></root>';,最后激活
加载外部 XML 文件或字符串
支持从文件、流、字符串加载:
- 从文件:
XMLDoc.LoadFromFile('data.xml'); - 从字符串:
XMLDoc.LoadFromXML('<person><name>Alice</name><age>30</age></person>'); - 从流(如
TStringStream):XMLDoc.LoadFromStream(Stream); - 加载后建议检查
XMLDoc.ParseError.ErrorCode = 0判断是否成功,否则读取ParseError.Reason获取错误信息
解析 XML(读取节点与属性)
通过 DocumentElement 开始遍历,常用方法有:
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~