十年網(wǎng)站開(kāi)發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無(wú)憂售后,網(wǎng)站問(wèn)題一站解決
grep名稱來(lái)自于g/re/p(globally search a regular expression and print,以正規(guī)表示法進(jìn)行全域查找以及打?。?是一個(gè)最初用于Unix操作系統(tǒng)的命令行工具。在給出文件列表或標(biāo)準(zhǔn)輸入后,grep會(huì)對(duì)匹配一個(gè)或多個(gè)正則表達(dá)式的文本進(jìn)行搜索,并只輸出匹配(或者不匹配)的行或文本。
創(chuàng)新互聯(lián)公司不只是一家網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司;我們對(duì)營(yíng)銷、技術(shù)、服務(wù)都有自己獨(dú)特見(jiàn)解,公司采取“創(chuàng)意+綜合+營(yíng)銷”一體化的方式為您提供更專業(yè)的服務(wù)!我們經(jīng)歷的每一步也許不一定是最完美的,但每一步都有值得深思的意義。我們珍視每一份信任,關(guān)注我們的成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)質(zhì)量和服務(wù)品質(zhì),在得到用戶滿意的同時(shí),也能得到同行業(yè)的專業(yè)認(rèn)可,能夠?yàn)樾袠I(yè)創(chuàng)新發(fā)展助力。未來(lái)將繼續(xù)專注于技術(shù)創(chuàng)新,服務(wù)升級(jí),滿足企業(yè)一站式營(yíng)銷型網(wǎng)站需求,讓再小的成都品牌網(wǎng)站建設(shè)也能產(chǎn)生價(jià)值!
命令名稱:grep, egrep, fgrep 命令作用:print lines matching a pattern 命令用法:grep [OPTIONS] PATTERN [FILE...] grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...] 參數(shù)選項(xiàng):-v 反向選取 -o 僅顯示匹配的字符串,而非字符串所在的行 -i 忽略字符串大小寫 -E 支持只用擴(kuò)展正則表達(dá)式 -A n 顯示匹配到字符串之后的n行 -B n 顯示匹配到字符串之前的n行 -C n 顯示匹配到字符串前后的n行 --color 高亮顯示匹配到的字符串 |
常見(jiàn)字符集:
[:space:] | 所以空白字符 |
[:punct:] | 所以標(biāo)點(diǎn)符號(hào) |
[:lower:] | 所有小寫字母 |
[:upper:] | 所以大寫字母 |
[:digit:] | 所有數(shù)字 |
[:alnum:] | 所有大小寫字母和數(shù)字 |
[:alpha:] | 所有大小寫字母 |
文件名通配:
* | 任意長(zhǎng)度的任意字符 |
? | 匹配任意單個(gè)字符 |
[] | 匹配指定范圍內(nèi)的任意單個(gè)字符 |
[^] | 匹配指定范圍以外的任意單個(gè)字符 |
基本正則表達(dá)式:
字符匹配 | . | 匹配任意單個(gè)字符 |
[] | 匹配指定范圍內(nèi)的任意單個(gè)字符 | |
[^] | 匹配指定范圍外的任意單個(gè)字符 | |
次數(shù)匹配 | * | 前面的字符可以出現(xiàn)任意次 |
\? | 前面的字符出現(xiàn)0次或者1次 | |
\{m\} | 前面的字符出現(xiàn)m次 | |
\{m,n\} | 前面的字符出現(xiàn)n次~m次 | |
\{m,\} | 前面的字符至少出現(xiàn)m次 | |
\{0,n\} | 前面的字符至多出現(xiàn)n次 | |
.* | 任意長(zhǎng)度的任意字符 | |
位置錨定 | ^ | 行首錨定,寫在模式的最左側(cè) |
$ | 行尾錨定,寫在模式的最右側(cè) | |
^$ | 匹配空行 | |
\< | 詞首錨定,出現(xiàn)于單詞左側(cè) | |
\> | 詞尾錨定,出現(xiàn)于單詞右側(cè) | |
分組 | \(\) | 匹配一個(gè)分組 |
\1 | 引用第1個(gè)括號(hào)所匹配到的內(nèi)容,而非模式本身 | |
\2 | 引用第2個(gè)括號(hào)所匹配到的內(nèi)容,而非模式本 身 |
擴(kuò)展正則表達(dá)式:
字符匹配 | . | 匹配任意單個(gè)字符 |
[] | 匹配指定范圍內(nèi)的任意單個(gè)字符 | |
[^] | 匹配指定范圍外的任意單個(gè)字符 | |
次數(shù)匹配 | * | 前面的字符可以出現(xiàn)任意次 |
? | 前面的字符出現(xiàn)0次或者1次 | |
+ | 前面的字符至少出現(xiàn)1次 | |
{m} | 前面的字符出現(xiàn)m次 | |
{m,n} | 前面的字符出現(xiàn)n次~m次 | |
{m,} | 前面的字符至少出現(xiàn)m次 | |
{0,n} | 前面的字符至多出現(xiàn)n次 | |
錨定 | ^ | 行首錨定,寫在模式的最左側(cè) |
$ | 行尾錨定,寫在模式的最右側(cè) | |
\<,\b | 詞首錨定,出現(xiàn)于單詞左側(cè) | |
\>,\b | 詞尾錨定,出現(xiàn)于單詞右側(cè) | |
^$ | 匹配空行 | |
分組 | () | 匹配一個(gè)分組 |
\1 | 引用第1個(gè)括號(hào)所匹配到的內(nèi)容,而非模式本身 |
grep練習(xí):
1、顯示/proc/meminfo文件中以大寫或小寫S開(kāi)頭的行;
[root@DB2 ~]# grep -i '^s' /proc/meminfo
[root@DB2 ~]# grep -E '^(S|s)' /proc/meminfo
[root@DB2 ~]# grep '^[S|s]' /proc/meminfo
2、顯示/etc/passwd文件中其默認(rèn)shell為非/sbin/nologin的用戶;
[root@DB2 ~]# grep -v "/sbin/nologin$" /etc/passwd | cut -d: -f1
3、顯示/etc/passwd文件中其默認(rèn)shell為/bin/bash并且ID號(hào)最大的用戶;
[root@DB2 ~]# grep '/bin/bash' /etc/passwd | sort -t: -k3 -n | tail -1 | cut -d: -f1
4、找出/etc/passwd文件中的一位數(shù)或兩位數(shù);
[root@DB2 ~]# grep '\<[0-9][0-9]\?\>' /etc/passwd
[root@DB2 ~]# grep '\<[0-9][0-9]\{0,1\}\>' /etc/passwd
5、顯示/boot/grub/grub.conf中以至少一個(gè)空白字符開(kāi)頭的行;
[root@DB2 ~]# grep '^[[:space:]]\{1,\}' /boot/grub/grub.conf
6、顯示/etc/rc.d/rc.sysinit文件中,以#開(kāi)頭,后面跟至少一個(gè)空白字符,而后又有至少一個(gè)非空白字符的行;
[root@DB2 ~]# grep --color '^#[[:space:]]\{1,\}[^[:space:]]\{1,\}' /etc/rc.d/rc.sysinit
7、找出netstat -tan命令執(zhí)行結(jié)果中以'LISTEN'結(jié)尾的行;
[root@DB2 ~]# netstat -tan | grep --color 'LISTEN[[:space:]]*$'
8、添加用戶bash, testbash, basher, nologin(SHELL為/sbin/nologin),而找出當(dāng)前系統(tǒng)上其用戶名和默認(rèn)shell相同的用戶;
[root@DB2 ~]# grep --color '^\([[:alnum:]]\{1,\}\):.*\1$' /etc/passwd
9、擴(kuò)展題:新建一個(gè)文本文件,假設(shè)有如下內(nèi)容: He like his lover. He love his lover. He like his liker. He love his liker. 找出其中最后一個(gè)單詞是由此前某單詞加r構(gòu)成的行。 cat < He like his lover. He love his lover. He like his liker. He love his liker. EOF [root@DB2 ~]# grep --color '\(l..e\).*\1r' 2.txt |
練習(xí):使用擴(kuò)展的正則表達(dá)式
10、顯示當(dāng)前系統(tǒng)上root、bin或halt用戶的默認(rèn)shell; [root@Oracle ~]# grep -E "^(root|bin|halt):" /etc/passwd | cut -d: -f7 |
11、找出/etc/rc.d/init.d/functions文件中某單詞后跟一組小括號(hào)“()”行; [root@Oracle ~]# grep -E -o "\<[[:alnum:]]+\>\(\)" /etc/rc.d/init.d/functions |
12、使用echo命令輸出一個(gè)路徑,而后使用grep取出其基名;
echo "/etc/sysconfig/" | grep -o -E "[[:alnum:]]+/?"
[root@Oracle ~]# echo "/etc/sysconfig/" | grep -o -E "[^/]+/?$" | cut -d/ -f1
sysconfig
[root@Oracle ~]# echo "/etc/sysconfig/" | grep -o -E "[[:alnum:]]+/?"
etc/sysconfig/
13、找出ifconfig命令結(jié)果中的1-255之間的數(shù)字; [root@Oracle ~]# ifconfig | grep -o -E --color "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>" |
14、挑戰(zhàn)題:寫一個(gè)模式,能匹配合理的ipv4地址; cat << EOF > 5.txt 192.168.1.1 127.0.0.1 10.127.5.1 202.96.128.166 202.96.128.255 255.255.255.255 239.0.1.25 240.1.1.1 0.0.0.1 EOF [root@Oracle ~]# grep -o -E --color "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-3][0-9])\>\.\<([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>\.\<([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>\.\<([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-4])\>" 5.txt |