【问题标题】:Convert Powershell output to a Markdown file将 Powershell 输出转换为 Markdown 文件
【发布时间】:2021-10-30 17:48:57
【问题描述】:

我有以下代码:

$xmlFile        = 'C:\Users\kraer\Desktop\bom.xml'

[xml]$xml = Get-Content $xmlFile


    $xml.bom.components.component | ForEach-Object {
        $finalObject = [PSCustomObject]@{
        'Name'      = $_.name
        'Version'   = $_.version
        'License'   = $_.licenses.license.id
    }
    Write-Output $finalObject
}

现在我想将我的 $finalObject 转换为 MarkDown 表。这里有什么可能吗?

对于另一个问题,我收到了这个答案,但现在它不适用于我的代码。

function ConvertTo-MarkDownTable {
    [CmdletBinding()] param(
        [Parameter(Position = 0, ValueFromPipeLine = $True)] $InputObject
    )
    Begin { $Init = $True }
    Process {
        if ( $Init ) {
            $Init = $False
            $_.PSObject.Properties.Name -Join '|'
            $_.PSObject.Properties.ForEach({ '-' }) -Join '|'
        }
        $_.PSObject.Properties.Value -Join '|'
    }
}

您还有其他解决方案吗?

感谢您的帮助

【问题讨论】:

  • 你可能打电话给ConvertTo-MarkDownTable $finalObject?将 ConvertTo-MarkDownTable 函数内的所有$_ 更改为$InputObject
  • “它不适用于我的代码。” - 请告诉我们您如何调用(并将参数传递给)ConvertTo-MarkDownTable
  • 我们还没有收到您的来信.. 我的回答解决了您的问题吗?如果是这样,请通过单击左侧的 图标来考虑accepting。这将帮助其他有类似问题的人更轻松地找到它,并有助于激励其他人回答您将来可能遇到的任何问题。
  • 抱歉,这几天我很忙。您的回答对我帮助很大,非常感谢。

标签: powershell scripting type-conversion markdown


【解决方案1】:

不知道你的 bom.xml 的内容,你可以试试这个稍微改编的函数版本:

function ConvertTo-MarkDownTable {
    [CmdletBinding()] param(
        [Parameter(Mandatory = $true, ValueFromPipeline = $true, Position = 0)] 
        $InputObject
    )
    Begin { 
        $headersDone = $false
        $pattern = '(?<!\\)\|'  # escape every '|' unless already escaped
    }
    Process {
        if (!$headersDone) {
            $headersDone = $true
            # output the header line and below that a dashed line
            # -replace '(?<!\\)\|', '\|' escapes every '|' unless already escaped
            '|{0}|' -f (($_.PSObject.Properties.Name -replace $pattern, '\|') -join '|')
            '|{0}|' -f (($_.PSObject.Properties.Name -replace '.', '-') -join '|')
        }
        '|{0}|' -f (($_.PsObject.Properties.Value -replace $pattern, '\|') -join '|')
    }
}

用法:

# load the xml from file
$xml= New-Object System.XML.XMLDocument
$xml.Load('C:\Users\kraer\Desktop\bom.xml')

$finalObject = $xml.bom.components.component | ForEach-Object {
    [PSCustomObject]@{
        'Name'    = $_.name
        'Version' = $_.version
        'License' = $_.licenses.license.id
    }
}
# convert to markdown
$finalObject | ConvertTo-MarkDownTable

附: $_.licenses.license.id 可能是错误的,因为它看起来像 licenses 是一个 array 许可证。你可能想在这里做这样的事情:

($_.licenses | ForEach-Object { $_.license.id }) -join '; '

【讨论】:

  • 感谢您的回答,但它不会创建降价表。
  • @bobby17jones 是的,对不起,我的错……我现在已经编辑了答案。
猜你喜欢
  • 1970-01-01
  • 2017-06-01
  • 2013-07-11
  • 2012-08-07
  • 2013-07-03
  • 2020-08-27
  • 2021-05-25
  • 2018-12-23
  • 2021-03-31
相关资源
最近更新 更多