在日常的開發工作中,處理 JSON 數據是非常常見的任務。而 awk 是一款非常強大的文本處理工具,也可以用來解析 JSON 數據。
首先,我們需要知道 JSON 數據的結構。JSON 數據由大括號包裹,大括號內是一系列鍵值對,每個鍵值對之間用逗號隔開。每個鍵值對由一個鍵和一個值組成,鍵和值之間用冒號隔開,鍵和值可以是任意數據類型。
{ "name": "Tom", "age": 20, "address": { "country": "China", "city": "Beijing" }, "hobbies": ["reading", "traveling", "swimming"] }
在 awk 中,可以使用 gawk-json 模塊來解析 JSON 數據。gawk-json 模塊包含了解析JSON數據的相關函數,可以很方便地從JSON數據中獲取所需的信息。
下面是一個簡單的 awk 腳本,用于解析上述 JSON 數據中的姓名和城市信息:
#!/bin/awk -f @include "json" BEGIN { FS = "\n" } { json = $0 root = parse_json(json) name = root["name"] city = root["address"]["city"] print "Name: " name print "City: " city }
在腳本的 BEGIN 塊中設置 FS 變量為換行符,這樣 awk 就會將 JSON 數據按行讀入。然后使用 parse_json 函數解析 JSON 數據,得到一個 JSON 根節點對象。通過根節點對象,我們可以使用鍵名獲取對應的值,也可以使用多層路徑來獲取嵌套的值。
上述腳本會輸出以下結果:
Name: Tom City: Beijing
通過學習 awk 的 JSON 解析功能,我們可以更加輕松地處理和分析 JSON 數據,提高工作效率。