正規表示式REGEXP

2021-08-10 19:22:32 字數 1447 閱讀 2763

正規表示式:regular expression, regexp

元字元:

.: 匹配任意單個字元

: 匹配指定範圍內的任意單個字元

[^]:匹配指定範圍外的任意單個字元

字元集合:[:digit:], [:lower:], [:upper:], [:punct:], [:space:], [:alpha:], [:alnum:]

匹配次數(貪婪模式):

*: 匹配其前面的字元任意次

a, b, ab, aab, acb, adb, amnb

a*b, a?b

a.*b

.*: 任意長度的任意字元

\?: 匹配其前面的字元1次或0次

\:匹配其前面的字元至少m次,至多n次\\

位置錨定:

^: 錨定行首,此字元後面的任意內容必須出現在行首

$: 錨定行尾,此字元前面的任意內容必須出現在行尾

^$: 空白行

\《或\b: 錨定詞首,其後面的任意字元必須作為單詞首部出現

\>或\b: 錨定詞尾,其前面的任意字元必須作為單詞的尾部出現

分組:\(\)

\(ab\)*

後向引用

\1: 引用第乙個左括號以及與之對應的右括號所包括的所有內容

\2:\3:

練習:1、顯示/proc/meminfo檔案中以不區分大小的s開頭的行;

grep -i '^s' /proc/meminfo

grep '^[ss]' /proc/meminfo

2、顯示/etc/passwd中以nologin結尾的行; 

grep 'nologin$' /etc/passwd

取出預設shell為/sbin/nologin的使用者列表

grep "nologin$' /etc/passwd | cut -d: -f1

取出預設shell為bash,且其使用者id號最小的使用者的使用者名稱

grep 'bash$' /etc/passwd | sort -n -t: -k3 | head -1 | cut -d: -f1

3、顯示/etc/inittab中以#開頭,且後面跟乙個或多個空白字元,而後又跟了任意非空白字元的行;

grep "^#[[:space:]]\[^[:space:]]" /etc/inittab

4、顯示/etc/inittab中包含了:乙個數字:(即兩個冒號中間乙個數字)的行;

grep ':[0-9]:' /etc/inittab

5、顯示/boot/grub/grub.conf檔案中以乙個或多個空白字元開頭的行;

grep '^[[:space:]]\' /boot/grub/grub.conf

6、顯示/etc/inittab檔案中以乙個數字開頭並以乙個與開頭數字相同的數字結尾的行;

grep '^\([0-9]\).*\1$' /etc/inittab

RegExp正規表示式

什麼是 regexp?regexp 是正規表示式的縮寫。當您檢索某個文字時,可以使用一種模式來描述要檢索的內容。regexp 就是這種模式。簡單的模式可以是乙個單獨的字元。更複雜的模式包括了更多的字元,並可用於解析 格式檢查 替換等等。您可以規定字串中的檢索位置,以及要檢索的字元型別,等等。var ...

正規表示式 RegExp()

字串處理 split 分割字串 charat 0 提取某個字元 substring 1,5 獲取字串 search a 返回位子,否則 1 正規表示式 字串匹配工具 str.match d g 所有匹配以陣列的形式返回 風格 風格 var re new regexp a var str abcdef...

RegExp 正規表示式

regexp 即 正規表示式 問題 因為要將頁面的值傳到後端,所以要先進行編碼 因為資料編碼後會變成 25e7 2 所以頁面值中如果已經包含特殊字元,會導致資料編碼異常,所以需要正規表示式規則進行輸入字元限制 案例 function checkreg id document.getelementby...