欧美一区二区三区,国内熟女精品熟女A片视频小说,日本av网,小鲜肉男男GAY做受XXX网站

awk截取json

awk是一款Unix和類Unix系統(tǒng)下的文本處理工具,也可以被用來(lái)處理JSON格式的文本數(shù)據(jù)。在JSON數(shù)據(jù)中,我們可以使用awk來(lái)截取所需要的信息,并且可以對(duì)JSON數(shù)據(jù)進(jìn)行篩選、排序和統(tǒng)計(jì)等操作。

在使用awk截取JSON數(shù)據(jù)時(shí),需要先將JSON數(shù)據(jù)轉(zhuǎn)換成行數(shù)據(jù)。可以使用以下命令將JSON數(shù)據(jù)轉(zhuǎn)換成行數(shù)據(jù):

cat file.json | tr -d '\n' | sed 's/},/}\n/g' | sed 's/^.*\[/{/' | sed 's/]$//'

這個(gè)命令的作用是將JSON數(shù)據(jù)中的換行符去掉,然后將“,”換行,最后用sed命令重構(gòu)JSON的頭和尾。處理后的結(jié)果就是一個(gè)行數(shù)據(jù)的JSON格式,可以使用awk來(lái)對(duì)其進(jìn)行操作。

假設(shè)我們有一個(gè)名為“file.json”的JSON文件,其中包含如下內(nèi)容:

{
"name": "Lucas",
"age": 25,
"sex": "male",
"address": {
"city": "Beijing",
"street": "Chaoyang District"
}
}
{
"name": "Lily",
"age": 28,
"sex": "female",
"address": {
"city": "Shanghai",
"street": "Pudong District"
}
}

我們可以使用awk來(lái)截取所有用戶的名字和所屬城市:

cat file.json | tr -d '\n' | sed 's/},/}\n/g' | sed 's/^.*\[/{/' | sed 's/]$//' | awk -F '[:,}]' '{print "name: "$4"\tcity: "$9}'

以上代碼的輸出結(jié)果為:

name: Lucas     city: Beijing
name: Lily      city: Shanghai

在awk的-F參數(shù)中,使用了多個(gè)分隔符“:”,“,”和“}”,這樣就可以將JSON數(shù)據(jù)中的各個(gè)字段分隔出來(lái)了,然后通過(guò)print命令輸出所需的字段。

awk截取JSON數(shù)據(jù)是一個(gè)很常見(jiàn)的需求,使用awk可以快速方便地提取所需的字段。同時(shí),通過(guò)awk的其他操作,還可以對(duì)JSON數(shù)據(jù)進(jìn)行更加復(fù)雜的處理。