Shell使用grep和sed命令提取json数据中指定字段的值

示例:

1.有一个example.txt文件,文件内容如下:

{“err_code”: 200,"err_msg": "this is no error", “status”: 1, “dev_name”: “mylinux”, “dev_id”: 123}

2.如果我们想要获取dev_id字段的值,可以在命令行下使用如下一行命令:

cat example.txt | sed 's/,/\n/g' | grep "dev_id" | sed 's/:/\n/g' | sed '1d' | sed 's/}//g'

Shell使用grep和sed命令提取json数据中指定字段的值_第1张图片

命令解释:

(1)第一个sed命令的意思是将json数据中的“,”替换为换行符“\n”,这样该串数据就变为每一行一个字段的内容,即按逗号分隔数据串。

Shell使用grep和sed命令提取json数据中指定字段的值_第2张图片

(2)第二个grep命令的意思是查找“dev_id”关键字,并单列出来。

(3)第三个sed命令的意思是将(2)中的结果再次按冒号“:”进行分隔。

(4)第四个sed命令的意思是将(3)中的结果,删除第一行内容,即删除“dev_id”行。

(5)最后一个sed命令的意思是将最后的花括号“}”用空字符替换,最终得到我们想要的值。

3.如果我们想要获取dev_name字段的值,可以在命令行下使用如下一行命令:

cat example.txt | sed 's/,/\n/g' | grep "dev_name" | sed 's/:/\n/g' | sed '1d' | sed 's/"//g'

Shell使用grep和sed命令提取json数据中指定字段的值_第3张图片

命令解释:

前面四个sed、grep命令见上面的解释。

由于前面四个命令我们得到的结果为“mylinux”,因此需要将其中的引号去掉才是我们最终想要的结果mylinux。

sed 's/"//g'   的意思是将前面的结果中的引号“”用空字符代替,最后的g参数表示替换所有符合的引号“”。

4.如果我们想把上述结果存进变量里使用的话,可以使用下面的命令:

dev_id=$(cat example.txt | sed 's/,/\n/g' | grep "dev_id" | sed 's/:/\n/g' | sed '1d' | sed 's/}//g')
echo $dev_id

同样的,对于dev_name字段,有如下命令:

dev_name=$(cat example.txt | sed 's/,/\n/g' | grep "dev_id" | sed 's/:/\n/g' | sed '1d' | sed 's/}//g')
echo $dev_name

5.后记

        以上仅为本人的一种实现方式,由于刚开始接触shell,对于grep以及sed的理解还不深入,写在这里也是用于记录,免得日后忘了。上面的实现方式可能比较麻烦,如果大家有更好的方法的话,欢迎留言讨论。

 

你可能感兴趣的:(linux日常问题)