Delphi中TXMLDocument需设Active=True才可用,支持MSXML/OpenXML;可加载文件/字符串/流,解析用DocumentElement遍历,生成节点须用OwnerDocument创建,保存时注意UTF-8编码处理。
Delphi 中使用 TXMLDocument 解析和生成 XML 是常见需求,但要注意它在不同版本中的行为差异(尤其是 Delphi 7 到 XE 系列),以及底层依赖(MSXML 或 OpenXML)。核心在于正确创建、加载、遍历和保存文档。
TXMLDocument 是一个封装类,本身不直接持有 XML 数据,而是代理到底层 DOM 对象。必须显式启用 Active 属性才能使用:
TXMLDocument,将 Active 属性设为 True;或代码中调用 XMLDoc.Active := True;
XMLDoc.DOMVendor := GetDOMVendor('OpenXML');(需引用 Xml.XMLDoc 和 Xml.xmldom)XMLDoc.LoadFromXML(' '); 或先 XMLDoc.Active := False; 再 XMLDoc.XML.Text := ' ';,最后激活支持从文件、流、字符串加载:
XMLDoc.LoadFromFile('data.xml');
XMLDoc.LoadFromXML('Alice 30 ');
TStringStream):XMLDoc.LoadFromStream(Stream);
XMLDoc.ParseError.ErrorCode = 0 判断是否成功,否则读取 ParseError.Reason 获取错误信息通过 DocumentElement 开始遍历,常用方法有:
Root := XMLDoc.DocumentElement;
NameNode := Root.ChildNodes.FindNode('name'); 或 Root.ChildNodes[0] 按索引访问NameNode.Text(注意:会自动合并所有子文本节点)Root.Attributes['version'] 或 Root.GetAttribute('version')
for i := 0 to Root.ChildNodes.Count - 1 do begin Node := Root.ChildNodes[i]; ... end;
所有节点操作需通过 OwnerDocument 创建,确保归属正确:
NewNode := XMLDoc.CreateElement('p
hone');
NewNode.Text := '13800138000';
NewNode.SetAttribute('type', 'mobile');
Root.ChildNodes.Add(NewNode); 或 Root.ChildNodes.Insert(0, NewNode);
Node.Text := 'New Value'; 或 Node.SetAttribute('id', '2');
Node.ParentNode.ChildNodes.Remove(Node);
保存结果:调用 XMLDoc.SaveToFile('output.xml'); 或读取 XMLDoc.XML.Text 获取字符串。注意编码问题——默认 UTF-16,如需 UTF-8 可用 TStringStream 配合 SaveToStream 并指定编码。