如何遍历JSON对象以使用jq提取特定的键值

时间:2019-09-07 18:58:50

标签: json export-to-csv jq

我是Bash脚本和jq的新手。我正在尝试从JSON对象中提取键值对nametranscription.normalized

我已经学会了如何从名称中获取所有值的列表,并分别进行规范化,但这并不是我真正想要的。

cat submission.json | jq '.documents[] .pages[] .fields[] .name, .documents[] .pages[] .fields[] .transcription.normalized'

我想知道是否需要执行某种循环,但不确定。我确实想要一个脚本,以一种可以轻松转储到CSV文件的格式提取这2个字段。

这是JSON外观的示例。

{
  "id": 1,
  "state": "complete",
  "substate": null,
  "exceptions": [],
  "name": "Sender Account Number",
  "output_name": null,
  "field_definition_attributes": {
    "required": false,
    "data_type": "Account Number",
    "multiline": false,
    "consensus_required": false,
    "supervision_override": null
  },
  "transcription": {
    "raw": "1685-0441-1",
    "normalized": "168504411",
    "source": "machine_transcription",
    "data_deleted": false,
    "user_transcribed": null,
    "row_index": null
  },
  "field_image_url": "/api/v4/image/be167a88-9d1d-43bc-82b2-3d96d8c06656?start_x=0.3110429607297866&start_y=0.1052441592299208&end_x=0.5696909842243418&end_y=0.16043316955780607"
}

1 个答案:

答案 0 :(得分:1)

您不需要循环。而且jq可以从数组中生成CSV。

jq -r '.documents[].pages[].fields[] | [.name, .transcription.normalized] | @csv' file