PowerShell生成复杂XML推荐五种方法:一、XmlDocument类逐步构建;二、Here-String配合XmlWriter流式写入;三、PSCustomObject结合模板化递归生成;四、加载XSD验证后填充;五、.NET Core 6+的LINQ to XML(XElement)链式构造。

如果您需要在PowerShell中生成具有嵌套元素、属性、命名空间和文本内容的XML文档,则不能依赖简单的字符串拼接或基础的ConvertTo-Xml cmdlet。以下是构建复杂XML结构的多种方法:
一、使用XmlDocument类逐步构建
XmlDocument提供完整的DOM操作能力,支持添加命名空间、设置属性、插入子节点及处理CDATA节等高级功能,适合对结构和顺序有严格要求的场景。
1、创建空XmlDocument对象并添加XML声明。
2、使用CreateElement方法创建根节点,并通过SetAttribute设置命名空间URI与前缀。
3、对每个需嵌套的子元素,调用AppendChild将新元素追加到父节点下。
4、为特定元素调用CreateAttribute创建属性节点,并使用SetAttributeNode挂载到目标元素。
5、对含特殊字符的文本内容,使用CreateCDataSection包裹后附加到对应元素。
二、使用Here-String配合XmlWriter流式写入
XmlWriter提供高性能、低内存占用的XML序列化路径,能精确控制缩进、编码、命名空间作用域及空元素格式,适用于大体积或高频率生成任务。
1、调用[Xml.XmlWriter]::Create()传入文件路径与XmlWriterSettings对象,启用Indent和OmitXmlDeclaration选项。
2、调用WriteStartDocument方法启动文档流。
3、调用WriteStartElement并传入本地名与命名空间URI,自动处理前缀绑定。
4、对每个属性调用WriteAttributeString,指定前缀、名称、命名空间URI与值。
5、对文本内容调用WriteString,对CDATA块调用WriteCData。
三、利用PSCustomObject与Select-Xml结合模板化生成
通过定义分层哈希表或PSCustomObject描述结构,再借助XPath定位与动态属性映射,可实现配置驱动的XML构造逻辑,提升可维护性与复用性。
1、定义包含Name、Attributes、Children、InnerText、CData等键的嵌套哈希表。
2、编写递归函数,接收哈希表与当前XmlDocument节点,按键名执行对应操作。
3、遇到Attributes键时遍历其子哈希表,对每项调用SetAttribute。
4、遇到Children键时递归调用自身,将返回的新节点附加至当前节点。
5、若存在InnerText键且无CData键,调用AppendChild(CreateTextNode());否则调用AppendChild(CreateCDataSection())。
四、加载XSD架构后使用XmlSchemaSet验证并填充
当XML必须严格符合预定义XSD规范时,可先加载架构,再基于XmlSchemaSet生成强类型XmlDocument实例,确保元素顺序、必需属性与数据类型合规。
1、使用XmlSchema.Read()从文件或字符串加载XSD内容,加入XmlSchemaSet。
2、调用XmlSchemaSet.Compile()验证架构有效性。
3、创建XmlDocument并调用Schemas.Add()绑定已编译架构。
4、调用LoadXml()载入符合该架构的初始XML片段(如仅含根节点)。
5、使用GetElementsByTagName()定位占位节点,替换为按XSD规则构造的完整子树。
五、调用.NET Core 6+中的LINQ to XML(XElement)
XElement支持函数式链式构造,语法简洁直观,原生支持命名空间前缀、嵌套初始化器、属性内联赋值及自动转义,适合脚本快速开发。
1、导入System.Xml.Linq命名空间:Add-Type -AssemblyName System.Xml.Linq。
2、使用XNamespace声明默认或带前缀的命名空间,例如$ns = [XNamespace]"http://example.com/ns"。
3、通过XElement构造函数直接嵌套子元素,形如[XElement]::new($ns + "Parent", [XElement]::new($ns + "Child", "value"))。
4、在元素名前添加命名空间变量实现前缀绑定,如$ns + "Item"。
5、使用new XAttribute("attrName", "value")作为XElement构造参数之一添加属性。










