0

我正在寻找使用 PowerShell 输出一些类似于 Python 脚本的 JSON:

 {
"run_date": "2020-08-27",
"total_queries": 4,
"number_results": 3,
"number_warnings": 1,
"number_errors": 5,
"build_url": "https://some-url.com",
"queries":{
    "query_a":{
        "database_a": "102 rows",
        "database_b": "Error: See pipeline logs for details"
    },
    "query_b": "No results",
    "query_c": {
        "database_a": "Warning: Number of results exceeded maximum threshold - 6509 rows",
        "database_c": "Error: See pipeline logs for details",
        "database_d": "Error: See pipeline logs for details"
    }
} }

(忽略上面的右括号,由于某种原因,它不会在此处正确格式化)。

我在 PowerShell 中使用 foreach 循环来按顺序运行每个查询,具体取决于它们需要在哪些数据库上运行。

我知道在 Python 中我可以像这样创建 JSON 模板:

options = {
'run_date': os.environ['SYSTEM_PIPELINESTARTTIME'].split()[0],
'total_queries': 0,
'number_results': 0,
'number_warnings': 0,
'number_errors': 0,
'build_url': 'options = {
'run_date': os.environ['SYSTEM_PIPELINESTARTTIME'].split()[0],
'total_hunts': 0,
'number_results': 0,
'number_warnings': 0,
'number_errors': 0,
'build_url': 'https://some-url.com',
'queries': {} }

然后使用类似的东西:

options['queries'][filename][database] = '{} rows'.format(len(data))

将数据添加到 Python 字典中。

我尝试过使用嵌套的 PSCustomObjects,但是当在同一个数据库上运行不同的查询时,我最终会发生冲突,因此它试图使用相同的 Key 向 PSCustomObject 添加一个值。我想知道在 PowerShell 中是否有一种很好的“本机”方式来执行此操作,就像在 Python 中一样。

4

2 回答 2

0

原来我只是有点白痴,不记得如何使用 PowerShell 对象。

最后首先将所有查询名称添加到父对象中,如下所示:

foreach($name in $getqueries){
$notiObj.queries | Add-Member -NotePropertyName $name.BaseName -NotePropertyValue ([PSCustomObject]@{})}

然后在循环中添加有关查询本身的信息:

$notificationObj.queries.$queryName | Add-Member -NotePropertyName $database -NotePropertyValue "$($dataTable.Rows.Count) Rows" 
于 2020-08-27T02:50:56.193 回答
0

如果所需的最终结果是Json文件,则实际上不需要使用复杂(而且相当胖)的[PSCustomObject]类型。相反,您可以只使用一个[HashTable](或一个有序字典,只需在哈希表前面加上前缀,例如[Ordered]@{...}:)

要从Json 文件转换哈希表ConvertFrom-Json -AsHashTable,请使用参数(在 PowerShell 6.0 中引入)。要构建模板(或仅了解 PowerShell 格式),您可能需要使用此ConvertTo-Expressioncmdlet:

$Json | ConvertFrom-Json -AsHashTable | ConvertTo-Expression

@{
        'number_errors' = 5
        'number_warnings' = 1
        'queries' = @{
                'query_b' = 'No results'
                'query_a' = @{
                        'database_a' = '102 rows'
                        'database_b' = 'Error: See pipeline logs for details'
                }
                'query_c' = @{
                        'database_a' = 'Warning: Number of results exceeded maximum threshold - 6509 rows'
                        'database_d' = 'Error: See pipeline logs for details'
                        'database_c' = 'Error: See pipeline logs for details'
                }
        }
        'build_url' = 'https://some-url.com'
        'run_date' = '2020-08-27'
        'number_results' = 3
        'total_queries' = 4
}

这意味着您可以将此模板分配给$Options如下:

$Options = @{
        'number_errors' = 5
        'number_warnings' = 1
        'queries' = @{ ...

并轻松更改嵌套对象中的属性,例如:

$Options.Queries.query_c.database_d = 'Changed'

或者向嵌套对象添加新属性:

$Options.Queries.query_a.database_c = 'Added'

导致:

$Options | ConvertTo-Json

{
  "run_date": "2020-08-27",
  "queries": {
    "query_a": {
      "database_c": "Added",
      "database_b": "Error: See pipeline logs for details",
      "database_a": "102 rows"
    },
    "query_b": "No results",
    "query_c": {
      "database_c": "Error: See pipeline logs for details",
      "database_d": "Changed",
      "database_a": "Warning: Number of results exceeded maximum threshold - 6509 rows"
    }
  },
  "number_results": 3,
  "build_url": "https://some-url.com",
  "total_queries": 4,
  "number_errors": 5,
  "number_warnings": 1
}
于 2020-08-27T07:19:46.773 回答