PowerShell 技能连载 - 简单解析设置文件(第三部分)

在前一个技能中我们了解了 ConvertFrom-StringData 如何将纯文本的键值对转换为哈希表。还缺少另一个方向的操作:将哈希表转为纯文本。有了它以后,您就拥有了一个将设置和信息保存到文件的小型框架。

我们首先创建一个包含一些数据的哈希表:

1
2
3
4
5
6
7
$test = @{
Name = 'Tobias'
ID = 12
Conf = 'PowerShell Conference EU'
}

$test

结果看起来如下:

1
2
3
4
5
Name                           Value
---- -----
Conf PowerShell Conference EU
Name Tobias
ID 12

以下是名为 ConvertFrom-Hashtable 的函数,传入一个哈希表,并将它转换为纯文本:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
filter ConvertFrom-Hashtable
{
$_.GetEnumerator() |
ForEach-Object {
# get hash table key and value
$value = $_.Value
$name = $_.Name

# escape "\" in strings
if ($value -is [string]) { $value = $value.Replace('\','\\') }

# compose key-value pair as plain text
'{0}={1}' -f $Name, $value
}
}

让我们看看哈希表是如何转换的:

1
2
3
4
5
6
PS> $test | ConvertFrom-Hashtable
Conf=PowerShell Conference EU
Name=Tobias
ID=12

PS>

您可以用 ConvertFrom-StringData 转换到另一种形式:

1
2
3
4
5
6
7
8
9
10
11
PS> $test | ConvertFrom-Hashtable | ConvertFrom-StringData

Name Value
---- -----
Conf PowerShell Conference EU
Name Tobias
ID 12



PS>

所以基本上,您可以将哈希表保存为纯文本,并在稍后使用它:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$test = @{
Name = 'Tobias'
ID = 12
Conf = 'PowerShell Conference EU'
}

$path = "$env:temp\settings.txt"

# save hash table as file
$test | ConvertFrom-Hashtable | Set-Content -Path $path -Encoding UTF8
notepad $path

# read hash table from file
Get-Content -Path $path -Encoding UTF8 |
ConvertFrom-StringData |
Out-GridView

请注意这种方法对简单的字符串和数字型数据有效。它不能处理复杂数据类型,因为这个转换操作并不能序列化对象。

PowerShell 技能连载 - 简单解析设置文件(第三部分)

http://blog.vichamp.com/2017/07/28/easy-parsing-of-setting-files-part-3/

作者

吴波

发布于

2017-07-28

更新于

2022-07-06

许可协议

评论