PowerShell可通过[xml]类型读取XML文件,如$config = Get-Content config.xml;通过属性访问节点,如$config.configuration.appSettings.add;可使用Where-Object筛选节点,修改value后调用$config.Save()保存;添加节点需用CreateElement创建并AppendChild插入;删除节点使用RemoveChild方法。操作后必须Save()才能持久化,建议增加异常处理提升脚本健壮性。

PowerShell 读取和修改 XML 配置文件非常方便,尤其适用于自动化部署、环境配置管理等场景。XML 文件结构清晰,PowerShell 内置的 .net 类库能直接加载和操作 XML 文档,无需额外依赖。
如何读取 XML 配置文件
使用 [xml] 类型强制转换可以轻松将 XML 文件加载为对象,之后通过属性访问节点内容。
示例 XML 文件 (config.xml):
<configuration> <appSettings> <add key="Server" value="localhost" /> <add key="Port" value="8080" /> <add key="DebugEnabled" value="true" /> </appSettings> </configuration>
PowerShell 读取代码:
[xml]$config = Get-Content -Path "config.xml" $server = $config.configuration.appSettings.add | Where-Object { $_.key -eq "Server" } Write-Host "当前服务器: $($server.value)"
也可以遍历所有 appSettings:
$config.configuration.appSettings.add | ForEach-Object { Write-Host "$($_.key) = $($_.value)" }
如何修改 XML 节点值
修改节点后需调用 Save() 方法保存到文件。
# 修改 Port 值 $portnode = $config.configuration.appSettings.add | Where-Object { $_.key -eq "Port" } $portNode.value = "9000" <h1>保存文件</h1><p>$config.Save("config.xml") Write-Host "端口已更新为 9000"</p>
注意:Where-Object 返回的是集合,若确保唯一可用索引或更精确查找方式。
添加新的 XML 节点
使用 InnerXml 或 CreateElement 方法创建并插入新节点。
# 创建新节点 $newNode = $config.CreateElement("add") $newNode.SetAttribute("key", "LogLevel") $newNode.SetAttribute("value", "Debug") <h1>添加到 appSettings</h1><p>$config.configuration.appSettings.AppendChild($newNode)</p><h1>保存</h1><p>$config.Save("config.xml")</p>
删除指定 XML 节点
找到目标节点后使用 RemoveChild() 删除。
# 删除 DebugEnabled 节点 $nodeToRemove = $config.configuration.appSettings.add | Where-Object { $_.key -eq "DebugEnabled" } if ($nodeToRemove) { $null = $config.configuration.appSettings.RemoveChild($nodeToRemove) $config.Save("config.xml") Write-Host "已删除 DebugEnabled 节点" }
基本上就这些。只要理解 XML 结构是树形对象模型,就能像操作普通对象一样读写属性和子节点。保存时务必调用 Save(),否则内存中修改不会持久化。实际使用中建议加文件存在性判断和异常处理,提升脚本健壮性。


