PowerShell创建XML文件有三种常用方法:使用XmlTextWriter可逐行构建并格式化文档,适合精细控制;通过[xml]类型动态创建节点并保存,适用于结构化数据生成;利用Here-String直接输出静态XML内容,最简洁高效。根据需求选择合适方式即可。

PowerShell 创建和写入 XML 文件非常简单,利用 .NET 提供的 XmlTextWriter 或直接操作 [xml] 类型即可。下面介绍几种常用方法,适合日常自动化任务使用。
使用 XmlTextWriter 创建 XML 文件
这是最基础的方法,适合需要逐行构建结构的场景。
- 创建 XmlTextWriter 对象,指定文件路径和编码
- 设置格式化选项(如缩进),提升可读性
- 按顺序写入声明、元素、属性和文本内容
- 最后调用 Flush() 和 Close() 保存文件
示例代码:
$writer = New-Object System.Xml.XmlTextWriter("C:\temp\config.xml", $null)
$writer.Formatting = "Indented"
$writer.Indentation = 2
$writer.WriteStartDocument()
$writer.WriteComment("Generated by PowerShell")
$writer.WriteStartElement("Configuration")
$writer.WriteElementString("Server", "Web01")
$writer.WriteElementString("Port", "8080")
$writer.WriteStartElement("Database")
$writer.WriteAttributeString("type", "MySQL")
$writer.WriteString("MainDB")
$writer.WriteEndElement()
$writer.WriteEndElement()
$writer.WriteEndDocument()
$writer.Flush()
$writer.Close()
使用 [xml] 类型动态构建并保存
这种方法更直观,适合在脚本中动态生成结构。
- 声明一个空的 [xml] 变量
- 使用 New-Object 创建节点并拼接
- 通过 Save() 方法写入文件
示例代码:
$xmlDoc = [xml]"" $root = $xmlDoc.DocumentElement $serverNode = $xmlDoc.CreateElement("Server") $serverNode.InnerText = "AppServer01" $portNode = $xmlDoc.CreateElement("Port") $portNode.InnerText = "443" $dbNode = $xmlDoc.CreateElement("Database") $dbAttr = $xmlDoc.CreateAttribute("env") $dbAttr.Value = "Production" $dbNode.Attributes.Append($dbAttr) | Out-Null $dbNode.InnerText = "ProdDB" $root.AppendChild($serverNode) | Out-Null $root.AppendChild($portNode) | Out-Null $root.AppendChild($dbNode) | Out-Null $xmlDoc.Save("C:\temp\output.xml")
直接通过 Here-String 写入静态 XML
如果数据结构固定,可以直接用 Here-String 快速输出。
这种方式最简洁,适合模板类配置文件。
示例代码:
$xmlContent = @""@ $xmlContent | Out-File -FilePath "C:\temp\settings.xml" -Encoding UTF8 30 true C:\logs C:\temp
基本上就这些常用方式。选择哪种取决于你的需求:精细控制用 XmlTextWriter,动态构造用 [xml] 对象,静态内容用 Here-String 即可。注意路径权限和编码设置,避免写入失败。










