gpt4 book ai didi

json - JQ如何从json值打印换行符而不是换行符

转载 作者:行者123 更新时间:2023-12-03 21:05:38 25 4
gpt4 key购买 nike

我有一些以 JSON 格式输出信息的日志。这是为了收集到elasticsearch。

一些测试人员和运维人员希望能够读取服务器上的日志。

这是一些示例 JSON:

{
"@timestamp": "2015-09-22T10:54:35.449+02:00",
"@version": 1,
"HOSTNAME": "server1.example",
"level": "WARN",
"level_value": 30000,
"logger_name": "server1.example.adapter",
"message": "message"
"stack_trace": "ERROR LALALLA\nERROR INFO NANANAN\nSOME MORE ERROR INFO\nBABABABABABBA BABABABA ABABBABAA BABABABAB\n"
}

等等。

是否可以让 Jq 打印换行符而不是\n 字符?

最佳答案

最初给出的输入不是非常有效的 JSON,并且不清楚所需的输出是什么,但以下内容可能会引起人们的兴趣。它是为当前版本的 jq(1.5 版)编写的,但可以很容易地适应 jq 1.4:

def json2qjson:
def pp: if type == "string" then "\"\(.)\"" else . end;
. as $in
| foreach keys[] as $k (null; null; "\"\($k)\": \($in[$k] | pp)" ) ;


def data: {
"@timestamp": "2015-09-22T10:54:35.449+02:00",
"@version": 1,
"HOSTNAME": "server1.example",
"level": "WARN",
"level_value": 30000,
"logger_name": "server1.example.adapter",
"message": "message",
"stack_trace": "ERROR LALALLA\nERROR INFO NANANAN\nSOME MORE ERROR INFO\nBABABABABABBA BABABABA ABABBABAA BABABABAB\n"
};

data | json2qjson

输出:
$ jq -rnf json2qjson.jq
"@timestamp": "2015-09-22T10:54:35.449+02:00"
"@version": 1
"HOSTNAME": "server1.example"
"level": "WARN"
"level_value": 30000
"logger_name": "server1.example.adapter"
"message": "message"
"stack_trace": "ERROR LALALLA
ERROR INFO NANANAN
SOME MORE ERROR INFO
BABABABABABBA BABABABA ABABBABAA BABABABAB
"

关于json - JQ如何从json值打印换行符而不是换行符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32715008/

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