将格式十六进制 PowerShell 表转换为原始十六进制转储



我在PowerShell中使用了Format-Hex命令来获取字符串的十六进制内容。我的命令"some_string" | format-hex在表中为我提供输出。我怎样才能把它变成一个原始的十六进制转储,所以它就像736f6d655f737472696e67

展开结果对象的 Bytes 属性,将每个字节的格式设置为两位十六进制数,然后连接它们:

("some_string" | Format-Hex | Select-Object -Expand Bytes | ForEach-Object { '{0:x2}' -f $_ }) -join ''

但是,编写自定义函数以将字符串转换为十六进制表示形式可能会更简单、更直接:

function ConvertTo-Hex {
    [CmdletBinding()]
    Param(
        [Parameter(
            Position=0,
            Mandatory=$true,
            ValueFromPipeline=$true,
            ValueFromPipelineByPropertyName=$true
        )]
        [string]$InputObject
    )
    $hex = [char[]]$InputObject |
           ForEach-Object { '{0:x2}' -f [int]$_ }
    if ($hex -ne $null) {
        return (-join $hex)
    }
}
"some_string" | ConvertTo-Hex

最新更新