結合示例說明shell是如何被解析的
經常寫shell,那么shell如何被解析的呢?

一、sed的經典示例
$符號在shell中解析為變量,但是在sed中代表文件的最后一行。
如何顯示/etc/passwd 的倒數第三行
redirect]# sed -n '$-2p' /etc/passwd
這個明顯是不行的,sed內部有一個行號計數器,一行一行讀取直到最后一行 ,$才是最后一行的行號。
如何解決?
先用wc -l計數,然后變量傳進去再打印倒數第三行。
redirect]# line=25
redirect]# sed -n "${line}p" /etc/passwd
注意不能用單引號,單引號屬于強引用,無法將變量解析。
如何要同時顯示最后一行和倒數第三行?
redirect]# sed -n "${line}p;$p" /etc/passwd
tcpdump:x:72:72::/:/sbin/nologin
這樣為何只顯示了倒數第三行內容呢?
第二個$ 屬于sed的最后一行,不應該暴露給shell解析。
redirect]# sed -n "${line}p;"'$p' /etc/passwd
tcpdump:x:72:72::/:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
這樣也是可以的
redirect]# sed -n "${line}p;\$p" /etc/passwd
tcpdump:x:72:72::/:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
redirect]# sed -n "${line}""p;\$p" /etc/passwd
tcpdump:x:72:72::/:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib
redirect]# sed -n ${line}"p;\$p" /etc/passwd
tcpdump:x:72:72::/:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
二、awk的經典示例
使用awk輸出hello world,在hello后增加單引號
redirect]# awk 'BEGIN{print "hello world"}'
hello world
redirect]# awk 'BEGIN{print "hello'"'"' world"}'
hello' world
這樣拆解開來看
'BEGIN{print "hello' "'" ' world"}'
redirect]# awk "BEGIN{print \"hello' world\"}"
hello' world
047是單引號的ASSIC值
redirect]# awk 'BEGIN{print "hello\047 world"}'
hello' world
# print 中雙引號的值都保留給awk
awk -v q="'" 'BEGIN{print "hello"q" world"}'
hello' world
到此這篇關于結合示例說明shell是如何被解析的的文章就介紹到這了,更多相關shell 解析內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Linux batch命令詳解(在系統(tǒng)不繁忙的時候執(zhí)行定時任務)
batch命令 用于在指定時間,當系統(tǒng)不繁忙時執(zhí)行任務,用法與at相似,這篇文章主要介紹了Linux batch命令(在系統(tǒng)不繁忙的時候執(zhí)行定時任務),需要的朋友可以參考下2024-02-02
如何使用 Bash 腳本中的time命令來統(tǒng)計命令執(zhí)行時間(中英雙語)
本文介紹了如何在Bash腳本中使用`time`命令來測量命令執(zhí)行時間,包括`real`、`user`和`sys`三個時間指標,并展示了如何格式化輸出和將結果保存到文件中,感興趣的朋友一起看看吧2025-01-01
Linux Shell腳本語句執(zhí)行失敗,后續(xù)語句繼續(xù)執(zhí)行的問題及解決
這篇文章主要介紹了Linux Shell腳本語句執(zhí)行失敗,后續(xù)語句繼續(xù)執(zhí)行的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06

