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

PowerShell 创建和写入 XML 文件非常简单,利用 .net 提供的 XmlTextWriter 或直接操作 [xml] 类型即可。下面介绍几种常用方法,适合日常自动化任务使用。
使用 XmlTextWriter 创建 XML 文件
这是最基础的方法,适合需要逐行构建结构的场景。
示例代码:
$writer = New-Object System.Xml.XmlTextWriter("C:tempconfig.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></Root>" $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:tempoutput.xml")
直接通过 Here-String 写入静态 XML
如果数据结构固定,可以直接用 Here-String 快速输出。
这种方式最简洁,适合模板类配置文件。
示例代码:
$xmlContent = @" <?xml version="1.0" encoding="utf-8"?> <Settings> <Timeout>30</Timeout> <DebugEnabled>true</DebugEnabled> <Paths> <LogPath>C:logs</LogPath> <TempPath>C:temp</TempPath> </Paths> </Settings> "@ $xmlContent | Out-File -FilePath "C:tempsettings.xml" -Encoding UTF8
基本上就这些常用方式。选择哪种取决于你的需求:精细控制用 XmlTextWriter,动态构造用 [xml] 对象,静态内容用 Here-String 即可。注意路径权限和编码设置,避免写入失败。


