如何在PowerShell中方便地操作XML文件?

PowerShell用[xml]类型可快速加载、查询、修改、保存XML文件。需用Get-Content -Encoding UTF8读取后强转,通过SelectSingleNode/SelectNodes(XPath)、InnerText、SetAttribute、CreateElement等DOM方法安全操作,最后调用Save()持久化。

PowerShell原生支持XML,用[xml]类型加速加载和修改,比手动解析快得多,关键是要避免直接字符串替换,改用DOM操作。

快速加载并验证XML文件

Get-Content读取后强转为[xml],PowerShell会自动解析成对象树。如果XML格式错误,会立刻报错,这本身就是一种轻量校验。

  • $xml = [xml](Get-Content "config.xml" -Encoding UTF8)
  • -Encoding UTF8防中文乱码(尤其Windows默认ANSI环境)
  • 加载后可直接访问根节点:$xml.DocumentElement.Name

安全修改节点内容(不破坏结构)

别用-replace改文本,改用.InnerText.SetAttribute(),确保XML语法始终合法。

  • 改文本值:$xml.SelectSingleNode("//setting[@name='timeout']").InnerText = "300"
  • 加新属性:$node.SetAttribute("enabled", "true")
  • 删节点:$node.ParentNode.RemoveChild($node)

添加新节点(保持命名空间和格式)

CreateElement()CreateAttribute()生成标准节点,再用AppendChild()插入,避免手拼XML字符串出错。

  • $newNode = $xml.CreateElement("item"); $newNode.InnerText = "value"
  • $xml.root.AppendChild($newNode) | Out-Null
  • 保存前记得$xml.Save("config.xml"),否则只在内存中生效

查询常用技巧(XPath最实用)

SelectSingleNode()SelectNodes()支持XPath,查配置、遍历列表都很顺手。

  • 查第一个匹配项:$xml.SelectSingleNode("/config/appSettings/add[@key='ApiUrl']")
  • 查所有同名节点:$xml.SelectNodes("//server") | ForEach-Object { $_.InnerText }
  • 注意XPath区分大小写,且//是全文档搜索,/是从根开始

基本上就这些——加载、查、改、存四步走清清楚楚,不用装额外模块,也不用写复杂正则。