简体   繁体   English

如何在UNIX中使用jq将JSON转换为tsv?

[英]How to convert JSON to tsv using jq in unix?

I need to convert this JSON to a TSV format. 我需要将此JSON转换为TSV格式。 I've a source file like this: 我有一个像这样的源文件:

{
  "event": "log",
  "timestamp": 1535306331840,
  "tags": [
    "info"
  ],
  "data": {
    "_id": "A301180827005852329209020",
    "msisdn": "6282134920902",
    "method": "get",
    "url": "/api/tcash/balance",
    "timeTaken": 32,
    "channelid": "UX"
  },
  "pid": 7920
}

Then I want to convert it to tsv which are consist of below column: 然后我想将其转换为包含以下列的tsv:

event, timestamp, tags, _id, msisdn, method, url, timeTaken, channelID, pid 

You just have to construct an array of atomic values. 您只需要构造一个原子值数组。 Since .tags is not atomic, in the following I'll assume (as suggested by @chepner) that we can use .tags|join(",") , though you might want to use something else, such as .tags|@csv : 由于.tags不是原子的,因此在下文中,我假设(如@chepner所建议的那样)我们可以使用.tags|join(",") ,尽管您可能想使用其他名称,例如.tags|@csv

[.event, .timestamp, (.tags | join(","))]
+ (.data|[._id, .msisdn, .method, .url, .timeTaken, .channelID])
+ [.pid]
| @tsv 

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM