給力的linux命令--jq簡(jiǎn)易教程

jq簡(jiǎn)介

jq可以對(duì)json數(shù)據(jù)進(jìn)行分片涂召、過(guò)濾坠非、映射和轉(zhuǎn)換,和sed芹扭、awk麻顶、grep等命令一樣,都可以讓你輕松地把玩文本舱卡。它能輕松地把你擁有的數(shù)據(jù)轉(zhuǎn)換成你期望的格式辅肾,而且需要寫(xiě)的程序通常也比你期望的更加簡(jiǎn)短。

jq是用C編寫(xiě)轮锥,沒(méi)有運(yùn)行時(shí)依賴矫钓,所以幾乎可以運(yùn)行在任何系統(tǒng)上。預(yù)編譯的二進(jìn)制文件可以直接在Linux舍杜、OS X和windows系統(tǒng)上運(yùn)行新娜,當(dāng)然在linux和OS X系統(tǒng)你需要賦與其可執(zhí)行權(quán)限;在linux系統(tǒng)中也可以直接用yum安裝既绩。
下載頁(yè)面:
https://stedolan.github.io/jq/download/

在知道jq命令之前概龄,我在linux系統(tǒng)中極少直接去命令去處理json數(shù)據(jù),除非只是簡(jiǎn)單地從中過(guò)濾某個(gè)字符串饲握,那就用grep結(jié)合正則表達(dá)式來(lái)解決私杜。所以,掌握了jq命令救欧,則可以讓linux命令和shell腳本在處理json數(shù)據(jù)時(shí)變得得心應(yīng)手衰粹。

jq簡(jiǎn)明教程

例子文件

為了便于演示jq的功能,我們?cè)谖募son.txt中保存如下內(nèi)容:

cat json.txt 
[{"name":"站長(zhǎng)工具","url":"http://tool.chinaz.com","address":{"city":"廈門(mén)","country":"中國(guó)"},"arrayBrowser":[{"name":"Google","url":"http://www.google.com"},{"name":"Baidu","url":"http://www.baidu.com"}]},{"name":"站長(zhǎng)之家","url":"http://tool.zzhome.com","address":{"city":"大連","country":"中國(guó)"},"arrayBrowser":[{"name":"360","url":"http://www.so.com"},{"name":"bing","url":"http://www.bing.com"}]}]

為了讓你理解文件中的內(nèi)容笆怠,對(duì)比jq的效果铝耻,在json解析工具中顯示為:

image

"."

最簡(jiǎn)單的jq程序是表達(dá)式".",它不改變輸入蹬刷,但可以將其優(yōu)美地輸出瓢捉,便于閱讀和理解。

cat json.txt | jq '.'

[
  {
    "name": "站長(zhǎng)工具",
    "url": "http://tool.chinaz.com",
    "address": {
      "city": "廈門(mén)",
      "country": "中國(guó)"
    },
    "arrayBrowser": [
      {
        "name": "Google",
        "url": "http://www.google.com"
      },
      {
        "name": "Baidu",
        "url": "http://www.baidu.com"
      }
    ]
  },
  {
    "name": "站長(zhǎng)之家",
    "url": "http://tool.zzhome.com",
    "address": {
      "city": "大連",
      "country": "中國(guó)"
    },
    "arrayBrowser": [
      {
        "name": "360",
        "url": "http://www.so.com"
      },
      {
        "name": "bing",
        "url": "http://www.bing.com"
      }
    ]
  }
]

[index]

輸出列表中的第一個(gè)元素办成,可以使用[index]:

cat json.txt | jq '.[0]'
{
  "name": "站長(zhǎng)工具",
  "url": "http://tool.chinaz.com",
  "address": {
    "city": "廈門(mén)",
    "country": "中國(guó)"
  },
  "arrayBrowser": [
    {
      "name": "Google",
      "url": "http://www.google.com"
    },
    {
      "name": "Baidu",
      "url": "http://www.baidu.com"
    }
  ]
}

管道線|

jq支持管道線|泊柬,它如同linux命令中的管道線——把前面命令的輸出當(dāng)作是后面命令的輸入。如下命令把.[0]作為{...}的輸入诈火,進(jìn)而訪問(wèn)嵌套的屬性兽赁,如.name.address.city状答。

觀察如下幾個(gè)命令,通過(guò)改變|前后的輸入和輸出來(lái)達(dá)到不同的效果:

cat json.txt | jq '.[0] | {name:.name,city:.address.city}'
{
  "name": "站長(zhǎng)工具",
  "city": "廈門(mén)"
}
cat json.txt | jq '.[0] | {name:.arrayBrowser[1].name,city:.address.city}'
{
  "name": "Baidu",
  "city": "廈門(mén)"
}
cat json.txt | jq ".[] | {name:.arrayBrowser[1].name,city:.address.city}"
{
  "name": "Baidu",
  "city": "廈門(mén)"
}
{
  "name": "bing",
  "city": "大連"
}

[]

如果希望把jq的輸出當(dāng)作一個(gè)數(shù)組刀崖,可以在前后加上[]

cat json.txt | jq "[.[] | {name:.arrayBrowser[1].name,city:.address.city}]"
[
  {
    "name": "Baidu",
    "city": "廈門(mén)"
  },
  {
    "name": "bing",
    "city": "大連"
  }
]

自定義key

在{}中惊科,冒號(hào)前面的名字是映射的名稱,你可以任意修改亮钦,如:

cat json.txt | jq "[.[] | {name_001:.arrayBrowser[1].name,city_002:.address.city}]"
[
  {
    "name_001": "Baidu",
    "city_002": "廈門(mén)"
  },
  {
    "name_001": "bing",
    "city_002": "大連"
  }
]

擴(kuò)展閱讀

http://www.json.cn/wiki.html
https://stedolan.github.io/jq/tutorial/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末馆截,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蜂莉,更是在濱河造成了極大的恐慌蜡娶,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,681評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件映穗,死亡現(xiàn)場(chǎng)離奇詭異窖张,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)蚁滋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,205評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)宿接,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人辕录,你說(shuō)我怎么就攤上這事睦霎。” “怎么了走诞?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,421評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵副女,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我蚣旱,道長(zhǎng)碑幅,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,114評(píng)論 1 300
  • 正文 為了忘掉前任姻锁,我火速辦了婚禮枕赵,結(jié)果婚禮上猜欺,老公的妹妹穿的比我還像新娘位隶。我一直安慰自己,他們只是感情好开皿,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,116評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布涧黄。 她就那樣靜靜地躺著,像睡著了一般赋荆。 火紅的嫁衣襯著肌膚如雪笋妥。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,713評(píng)論 1 312
  • 那天窄潭,我揣著相機(jī)與錄音春宣,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛月帝,可吹牛的內(nèi)容都是我干的躏惋。 我是一名探鬼主播,決...
    沈念sama閱讀 41,170評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼嚷辅,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼簿姨!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起簸搞,我...
    開(kāi)封第一講書(shū)人閱讀 40,116評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤扁位,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后趁俊,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體域仇,經(jīng)...
    沈念sama閱讀 46,651評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,714評(píng)論 3 342
  • 正文 我和宋清朗相戀三年则酝,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了殉簸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,865評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡沽讹,死狀恐怖般卑,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情爽雄,我是刑警寧澤蝠检,帶...
    沈念sama閱讀 36,527評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站挚瘟,受9級(jí)特大地震影響叹谁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜乘盖,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,211評(píng)論 3 336
  • 文/蒙蒙 一焰檩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧订框,春花似錦析苫、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,699評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至矛物,卻和暖如春茫死,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背履羞。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,814評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工峦萎, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留屡久,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,299評(píng)論 3 379
  • 正文 我出身青樓爱榔,卻偏偏與公主長(zhǎng)得像涂身,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子搓蚪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,870評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容

  • Ubuntu的發(fā)音 Ubuntu,源于非洲祖魯人和科薩人的語(yǔ)言雳灾,發(fā)作 oo-boon-too 的音漠酿。了解發(fā)音是有意...
    螢火蟲(chóng)de夢(mèng)閱讀 99,369評(píng)論 9 467
  • linux資料總章2.1 1.0寫(xiě)的不好抱歉 但是2.0已經(jīng)改了很多 但是錯(cuò)誤還是無(wú)法避免 以后資料會(huì)慢慢更新 大...
    數(shù)據(jù)革命閱讀 12,176評(píng)論 2 33
  • 命令行的藝術(shù) 前言 基礎(chǔ) 日常使用 文件及數(shù)據(jù)處理 系統(tǒng)調(diào)試 單行腳本 冷門(mén)但有用 僅限 OS X 系統(tǒng) 僅限 W...
    進(jìn)擊的諾基亞閱讀 3,854評(píng)論 0 19
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)谎亩,斷路器炒嘲,智...
    卡卡羅2017閱讀 134,716評(píng)論 18 139
  • 最怨紅塵別離分,茶飯不思懶撫琴匈庭,任由繁花空自放夫凸,獨(dú)倚琴寐夢(mèng)郎君!
    未來(lái)李想閱讀 181評(píng)論 0 0