使用jq创建.csv文件

时间:2019-02-02 17:36:48

标签: json csv jq

此主题以前曾提出过,但是答复并不能完全解决我的问题,下面将对此进行详细介绍。

我有来自API调用的以下JSON文件。...

{
  "status": "ok",
  "meta": {
    "count": 3
  },
  "data": {
    "1030907370": {
      "client_language": "en",
      "last_battle_time": 1548555418,
      "account_id": 1030907370,
      "created_at": 1525288212,
      "updated_at": 1548557165,
      "private": null,
      "global_rating": 3906,
      "clan_id": null,
      "nickname": "Knightly_Gunner",
      "logout_at": 1548557161
    },
    "1020786770": {
      "client_language": "ja",
      "last_battle_time": 1548948444,
      "account_id": 1020786770,
      "created_at": 1465998341,
      "updated_at": 1548948547,
      "private": null,
      "global_rating": 4396,
      "clan_id": null,
      "nickname": "black_black_boss",
      "logout_at": 1548948544
    },
    "1018984431": {
      "client_language": "en",
      "last_battle_time": 1548550089,
      "account_id": 1018984431,
      "created_at": 1456254986,
      "updated_at": 1548550089,
      "private": null,
      "global_rating": 1666,
      "clan_id": null,
      "nickname": "doctordon",
      "logout_at": 1548550016
    }
  }
}

使用以下jq查询。...

  

jq'.data | to_entries [] | [.key,.value.client_language,   .value.global_rating]”

我得到以下输出,正是我需要的数据,它们整齐地包装在数组中。...

[
  "1030907370",
  "en",
  3906
]
[
  "1020786770",
  "ja",
  4396
]
[
  "1018984431",
  "en",
  1666
]

我需要将此数据上传到MS Access数据库,因此需要将其转换为.csv文件,因此我的查询现在看起来像这样。...

  

jq'.data | to_entries [] | [.key,.value.client_language,   .value.global_rating] | @csv'

生成的输出是....

"\"1030907370\",\"en\",3906"
"\"1020786770\",\"ja\",4396"
"\"1018984431\",\"en\",1666"

但这不是真正的.csv文件,不适用于MS Access或Excel。我需要的是看起来像这样的输出。...

"1030907370","en",3906
"1020786770","ja",4396
"1018984431","en",1666

但这是我的问题所在!在实现jq查询所需的输出方面,我将提供一些帮助,我们将不胜感激。 谢谢!

1 个答案:

答案 0 :(得分:2)

使用原始模式(-r)

jq -r '.data | to_entries[] | [.key, .value.client_language, .value.global_rating] | @csv'
  

- 原始输出/ -r:

     

使用此选项,如果过滤器的结果是一个字符串那么这将是   直接写入标准输出,而不是格式化为   JSON字符串引号。这对于让jq过滤器说话很有用   非基于JSON的系统。