将嵌套 JSON 数据精准转换为 CSV(含自定义列头)的 jq 实战教程

本文详解如何使用 jq 工具从结构化 JSON 中提取指定字段(如 .Columns[].Id 作为 CSV 表头、.Rows[].Values 作为数据行),生成标准 CSV 输出,兼顾可读性、健壮性与实际工程需求。

本文详解如何使用 jq 工具从结构化 JSON 中提取指定字段(如 `.Columns[].Id` 作为 CSV 表头、`.Rows[].Values` 作为数据行),生成标准 CSV 输出,兼顾可读性、健壮性与实际工程需求。

在数据处理与 ETL 场景中,常需将 API 返回的嵌套 JSON(如报表服务响应)快速转为 CSV 供 Excel 或下游系统消费。本例 JSON 具有典型二维表结构:Columns 数组定义字段元信息(含 Id 字段作为逻辑列名),Rows 数组以 Values 列表形式存储每行原始值。目标是忽略 QueryHandle、RowCount 等无关字段,仅导出纯净 CSV。

✅ 核心 jq 命令解析

最简洁有效的解决方案如下:

jq -r '[.Columns[].Id], (.Rows[].Values) | @csv' input.json

执行后输出:

"ItemName","Date","Qty"
"ITEM1","10-MAY-2024","100"
"ITEM2","20-MAY-2024","200"
"ITEM3","30-MAY-2024","400"

⚠️ 注意事项与进阶技巧

✅ 总结

该方案以声明式思维直击 JSON 结构本质:用数组聚合表头,用流式展开处理行数据,交由 @csv 完成标准化序列化。相比通用转换工具(如 jq '.[] | @csv'),它精准控制字段来源,规避了嵌套层级误解析风险,是处理“带元数据的表格型 JSON”的最佳实践。推荐在 CI/CD 流水线、运维脚本或数据清洗任务中直接复用。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。