2012-09-13 7 views
5

を使用して表をハッシュするXML:XMLは、私が変換したいのPowershell

$invocation = (Get-Variable MyInvocation).Value 
$directorypath = Split-Path $invocation.MyCommand.Path 
$File = $directorypath + '\config.xml' 
$CONFIG = "CONFIG" 
$CFG = [xml] (gc $File) 

$CFG.test.ipAddress 
Name    Value 

ipAddress  10.2.1.90 
gitDir   C:\git\project 
gitArchiveDir C:\git\archive 
apacheDocroot /var/www 
apacheUsername root 

は現在、このreadメソッドを使用して:ハッシュテーブルに

<TEST> 
    <ipAddress value="10.2.1.90"/> 
    <gitDir value="C:\git\project"/> 
    <gitArchiveDir value="C:\git\archive"/> 
    <apacheDocroot value="/var/www"/> 
    <apacheUsername value="root"/> 
</TEST> 

答えて

15

これはトリックを行う必要があります:

PS C:\> $CFG = [xml]@' 
>> <TEST> 
>>  <ipAddress value="10.2.1.90"/> 
>>  <gitDir value="C:\git\project"/> 
>>  <gitArchiveDir value="C:\git\archive"/> 
>>  <apacheDocroot value="/var/www"/> 
>>  <apacheUsername value="root"/> 
>> </TEST> 
>> '@ 
>> 
PS C:\> $ht = @{} 
PS C:\> $CFG.test.ChildNodes | Foreach {$ht[$_.Name] = $_.Value} 
PS C:\> $ht 

Name       Value 
----       ----- 
apacheUsername     root 
gitArchiveDir     C:\git\archive 
ipAddress      10.2.1.90 
apacheDocroot     /var/www 
gitDir       C:\git\project 
関連する問題