gpt4 book ai didi

json - 在Powershell中从JSON转换为CSV

转载 作者:行者123 更新时间:2023-12-03 00:55:54 27 4
gpt4 key购买 nike

这是我的csv:

"name,data
Play,http://{gho}.domain.com/
BDomain,domain.com
Charts,2
Compress,0
CompressJ,0" | ConvertFrom-Csv | ConvertTo-Json
给我:
[
{
"name": "Play",
"data": "http://{gho}.domain.com/"
},
{
"name": "BDomain",
"data": "domain.com"
},
{
"name": "Charts",
"data": "2"
},
{
"name": "Compress",
"data": "0"
},
{
"name": "CompressJ",
"data": "0"
}
]
现在,我想从json中获取该csv,但是|的链ConvertFrom-Json | ConvertTo-CSV无法正常工作,我很好奇为什么不呢?

最佳答案

为了使Steven's helpful answer具有简洁的摘要和跨版本的观点,请执行以下操作:

  • PowerShell [Core] v7 + 中,不需要额外的工作:将| ConvertFrom-Json | ConvertTo-Csv附加到您的代码中可以按原样进行。
  • Windows PowerShell和PowerShell [Core] v6.x 中,您需要强制枚举ConvertFrom-Json的输出以使ConvertTo-Csv正常工作,因为与PowerShell的通常行为相反,ConvertFrom-Json会作为一个整体输出JSON数组管道的单个对象。
  • 事实是这种行为很不正常,这促使v7 +进行了更改-有关背景信息,请参见this answer
  • 强制枚举的最简单方法-即将输出为一个整体的数组/集合的元素一一发送到管道,是使用(...),即grouping operator

  • # Works in all PowerShell versions, but in v7+ the (...) is no longer necessary.
    (
    "name,data
    Play,http://{gho}.domain.com/
    BDomain,domain.com
    Charts,2
    Compress,0
    CompressJ,0" | ConvertFrom-Csv | ConvertTo-Json |
    ConvertFrom-Json
    ) | ConvertTo-Csv -NoTypeInformation
    这样产生:
    "name","data"
    "Play","http://{gho}.domain.com/"
    "BDomain","domain.com"
    "Charts","2"
    "Compress","0"
    "CompressJ","0"

    关于json - 在Powershell中从JSON转换为CSV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64014087/

    27 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com