我正在尝试读取一个配置文件,其中包含一些键值对,如下所示:
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中的哈希表有一些奇怪之处,但无法在避免这些奇怪之处的过程中抓住机会。请帮我解决这个问题。
发布于 2011-03-24 08:35:03
如果您不想修改文件:
$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\发布于 2011-03-24 08:21:50
首先,修改您的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\serverPD:修改文件为一行
>> (gc .\keyval.txt) | % { $_ -replace '\\', '\\'} | Set-Content .\keyval.txt发布于 2011-03-24 11:05:10
$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\https://stackoverflow.com/questions/5413035
复制相似问题