shell指令碼迅速擷取access日誌中的某個參數

來源:互聯網
上載者:User

例如我們統計sid,access 日誌如下:

203.142.196.181 - - [07/Jan/2009:06:02:58 +0900] "GET /ad/queryphp.jsp?v=1.5&ct=i02&tos=A&key=%3F%3F%3F&sid=100575311&enc=SJIS HTTP/1.0" 200 944 "-" "{KDDI-SN3B UP.Browser/6.2.0.13.1.5 (GUI) MMP/2.0}" 113185 1177

僅使用awk即可完成,先按照"sid="分割,取第二列,然後以"&"為分割,取第一列,OK

awk -F"sid=" '{print $2}' test |awk -F"&" '{print $1}'

另外一個辦法,新學的,使用echo的掐頭去尾的方法

a=$(echo string); #源字串

b=$(echo "${a##*sid=}") #恰頭,截取到sid後面的資料

echo "${b%%&*}" #去尾,把&後面的都截掉

太強大了!!!!!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.