当前位置:网站首页 > 更多 > 玩电脑 > 正文

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

作者:精品下载站 日期:2024-12-14 04:48:30 浏览:14 分类:玩电脑

PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?


[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

PowerShell JSON 格式的定义

JSON 格式还代表 JavaScript 对象表示法格式,它是一种开放标准格式,采用人类可读格式,主要用于浏览器和客户端之间更快的通信,因为它易于处理,并且可以使用 Invoke 等 Web 命令作为 PowerShell 数据进行检索WebRequest 和调用 RestMethod。尽管它的名字如此,这种语言与 JavaScript 格式有很大不同。

语法:

JSON 语言使用以下语法。

{
"String":"Value"
}

以上是JSON对象格式的简单语法。它具有属性标头和值,两者均由冒号 ( : ) 分隔,这意味着特定标头具有该特定值。

JSON array Syntax,
{
"String": [
Value1,
Value2
]
}

上面的语法显示 String 属性标头有两个数组值:Value1 和 Value2。

Complex JSON structure,
{
"String":[
{
"String1":"Value1",
"String2":"Value2"
},
{
"String3":"Value3",
"String4":[
"Value4",
"Value5"
]
}
]
}

上面的语法显示了 JSON 格式的复杂结构,其中包含字符串及其值、数组以及子字符串和值的组合。

JSON 类型在 PowerShell 中如何工作?

JavaScript 对象表示法或 JSON 文件具有 .json 语法。正如我们在上面的语法部分中看到的,JSON 是一个字符串和一个值对,并且有多个这样的字符串和值彼此关联,它还包含数组以及字符串和值的子组,并且可以创建复杂的结构。

您可以在任何编辑器中编写 JSON 文件,因为它是一种简单的文本格式,但要创建一个无错误的 JSON 文件,您可以使用 VS Code,因为它会在缺少任何语法时显示错误。第二件事,创建完 JSON 文件后,您还可以在线验证 JSON 文件。有几个网站会验证 JSON 文件,但 https://jsonlint.com/ 是验证 JSON 文件的热门网站。

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

创建并验证 JSON 文件后,我们的任务是在 PowerShell 中读取 JSON 文件。 PowerShell 使用两个 cmdlet ConvertTo-JSONConvertFrom-JSON 来处理 JSON 文件。

ConvertTo-JSON cmdlet 将任何可能的输出转换为 JSON 格式,ConvertFrom-JSON cmdlet 将 JSON 输入转换为自定义对象或哈希表格式。首先,我们将检查上面创建的示例输入 JSON 文件以及如何使用 ConvertFrom-JSON 命令。

{
"Company":"AeroSpace",
"HeadOffice":"Russia",
"BranchOffices":[
"India",
"Australia"
]
}

如果您直接使用 JSON 文件,则可以使用以下命令将输出转换为哈希表格式。

Get-Content .\Test1.json | ConvertFrom-Json

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

或者您可以直接使用以下命令,而无需将文件保存为 JSON。

$jsoninput = '{
"Company":"AeroSpace",
"HeadOffice":"Russia",
"BranchOffices":[
"India",
"Australia"
]
}'
$jsoninput | ConvertFrom-Json

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

要将任何输出转换为 JSON 格式,您需要使用 ConvertTo-JSON 命令,如下所示。

Get-Process notepad++ | Select Name, id, WorkingSet, CPU | ConvertTo-Json

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

在 JSON 结构中,布尔值 $true$false 分别定义为 truefalse,而 $null 定义为null。请参阅下面的示例。

Get-ChildItem -Path C:\TempAug2020.txt | ConvertTo-Json

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

您可以在上面的输出中看到定义了 null 和 true,并且使用 /Date 提到了日期格式,并且在双反斜杠中定义了路径 (“\ ” ) 而不是单个反斜杠。

示例

1. 将命令输出转换为 JSON 文件。

我们可以使用 ConvertTo-JSON 管道命令将几乎任何命令输出转换为 JSON 格式。例如,

Get-Process chrome | Select Name, ID, WorkingSet, CPU, PagedMemorySize64  | Select -First 3  |  ConvertTo-Json

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

您还可以使用-compress参数压缩输出,以便输出显示在一行中,如下所示。

Get-Process chrome | Select Name, ID, WorkingSet, CPU, PagedMemorySize64  | Select -First 3  |  ConvertTo-Json -Compress

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

2. 将 JSON 输出转换为数组。

要将 JSON 输出转换为数组,我们需要使用 -AsArray 参数。

请注意:此参数仅在 .Net Core 版本(PowerShell 6.0 及更高版本)中受支持,但 6.0 以下版本(.Net Framework 版本)不支持。

不转换为数组,

Get-Date  | ConvertTo-Json

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

转成数组后,

Get-Date  | ConvertTo-Json -AsArray

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

将 JSON 输出转换为数组时,会添加方括号。

3. 使用Invoke-Webrequest

您可以利用 JSON 命令来处理网站输出数据。例如,我们有一个 URL https://www.reddit.com/r/todayilearned/top.json?limit=100,它以 JSON 格式显示特定页面的 Reddit 前 100 篇帖子。

Invoke-WebRequest -Uri "https://www.reddit.com/r/todayilearned/top.json?limit=100" | ConvertFrom-Json

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

要阅读这些发布内容的标题,

$Out = Invoke-WebRequest -Uri "https://www.reddit.com/r/todayilearned/top.json?limit=100" | ConvertFrom-Json
$out.data.children.data | Select Title

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

上面的命令类似于 RestAPI 命令,它会自动格式化 Web JSON 输出数据,而无需使用外部 ConvertFrom-JSON 命令。

Invoke-RestMethod -Uri "https://www.reddit.com/r/todayilearned/top.json?limit=100"

4. 将输出转换为HashTable的JSON命令

使用 JSON 命令,我们可以将 cmdlet 的输出直接转换为哈希表,如下所示。

Get-Service | ConvertTo-Json | ConvertFrom-Json

输出:

[玩转系统] PowerShell JSON 格式 | JSON 类型在 PowerShell 中如何工作?

您还可以选择几个字段,

Get-Service | Select Name, Starttype, Status | ConvertTo-Json | ConvertFrom-Json

结论

JSON 格式已经超越了 XML 格式的使用,因为它更容易处理,对于使用大量内容的网站来说,浏览器加载速度更快,而且这种格式比 XML 格式轻得多。 JSON 文件在基础设施开发自动化中也很有用,它利用基础设施即代码 (IaaS) 格式,并由云技术以及主要是 Azure 用来与 Azure DevOps 和 ARM 模板配合使用,以批量快速部署基础设施资源。

您需要 登录账户 后才能发表评论

取消回复欢迎 发表评论:

关灯