我正在尝试读取一个包含一些键值对的配置文件,如下所示:
age = 7
server = \\server\
destination = \\nas\public\server\
以下是我用来阅读文件的脚本:
gc "keyval.txt" | % -begin {$h=@{}} -process { $k = [regex]::split($_,'='); if(($k[0].CompareTo("") -ne 0) -and ($k[0].StartsWith("[") -ne $True)) { $h.Add($k[0], $k[1]) } }
$h #THIS PRINTS THE KEYS and VALUES
$h.get_item("server") #THIS DOESN'T DO ANYTHING
$h.server #THIS DOESNT DO ANYTHING AS WELL
我了解到在PowerShell中有一些奇怪的哈希表,但是无法避开棘手的方法。请帮我解决这个问题。
答案 0 :(得分:3)
如果您不想修改文件:
$re = '\s*(\w+)\s*=\s*(\S+)'
Get-Content \temp\foo.txt |
Foreach {$ht=@{}} {if ($_ -match $re) {$ht.($matches[1]) = $matches[2]}} {$ht}
Name Value
---- -----
age 7
server \\server\
destination \\nas\public\server\
答案 1 :(得分:2)
首先修改你的txt以应用我要教你的方法。地下每一个值部分都必须通过c#解释,所以像\ s或\ p这样的东西都不好,因为它们没有任何意义。所以要有反斜杠你需要用反斜杠来逃避它,例如\\\\意味着两个反斜杠。修复文件后,您必须读取文件的所有内容并应用convertfrom-stringdata cmdlet。这是代码,享受。
>> $textfromfile = [IO.File]::ReadAllText((resolve-path .\keyval.txt))
>> $hash = ConvertFrom-StringData $textfromfile
>> $hash
Name Value
---- -----
server \\server\
age 7
destination \nas\public\server
PD:修改文件是一行
>> (gc .\keyval.txt) | % { $_ -replace '\\', '\\'} | Set-Content .\keyval.txt
答案 2 :(得分:2)
$h = @{}
gc keyval.txt |% {
$h[$_.split("=")[0].trim()] = $_.split("=")[1].trim()
}
$h
$h.get_item("server")
$h.server
Name Value
---- -----
age 7
server \\server\
destination \\nas\public\server\
\\server\
\\server\