如何通过PowerShell从XML中获取值?

17

我有一个包含以下数据的XML文件

<?xml version="1.0" encoding="windows-1251" ?>
<ValCurs Date="06/06/2012" name="Курби асъор">
 <Valute ID="036">
   <CharCode>AUD</CharCode> 
   <Nominal>1</Nominal> 
   <Name>Доллари Австралия</Name> 
   <Value>4,6430</Value> 
  </Valute>
 <Valute ID="944">
   <CharCode>AZN</CharCode> 
   <Nominal>1</Nominal> 
   <Name>Манати Озарбой&#1207;он</Name> 
   <Value>6,0677</Value> 
  </Valute>
 <Valute ID="826">
   <CharCode>GBP</CharCode> 
   <Nominal>1</Nominal> 
   <Name>Фунт-стерлинги Ингилистон</Name> 
   <Value>7,3156</Value> 
   </Valute>
...

如何在Valute的属性ID等于826时,从NominalValue节点获取数据?

以及其他

1个回答

44
你可以通过将字符串转换为 [xml] 来简单地读取 XML:
$xml = [xml](Get-Content foo.xml)

那么你可以使用

$xml.ValCurs.Valute | Where-Object {$_.ID -eq 826} | Select-Object Nominal,Value

或更短:

$xml.ValCurs.Valute | ? {$_.ID -eq 826} | select Nominal,Value

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接