RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux中的Grep正則表達(dá)式詳細(xì)資料說(shuō)明

Wildesbeast ? 來(lái)源:Linux公社 ? 作者:醉落紅塵 ? 2020-06-21 11:39 ? 次閱讀

grep是Linux中用于文本處理的最有用和功能最強(qiáng)大的命令之一。 grep在一個(gè)或多個(gè)輸入文件中搜索與正則表達(dá)式匹配的行,并將每條匹配的行寫(xiě)入標(biāo)準(zhǔn)輸出。

在本文中,我們將探討在grep的GNU版本中如何使用正則表達(dá)式的基礎(chǔ),大多數(shù)Linux操作系統(tǒng)默認(rèn)情況下都提供此功能。

Grep正則表達(dá)式

正則表達(dá)式或正則表達(dá)式是與一組字符串匹配的模式。模式由運(yùn)算符,構(gòu)造文字字符和元字符組成,它們具有特殊的含義。 GNU grep支持三種正則表達(dá)式語(yǔ)法,Basic,Extended和Perl兼容。

最簡(jiǎn)單的形式是,當(dāng)沒(méi)有給出正則表達(dá)式類型時(shí),grep會(huì)將搜索模式解釋為基本正則表達(dá)式。要將模式解釋為擴(kuò)展的正則表達(dá)式,請(qǐng)使用-E(或--extended-regexp)選項(xiàng)。

在GNU的grep實(shí)現(xiàn)中,基本正則表達(dá)式和擴(kuò)展正則表達(dá)式語(yǔ)法之間沒(méi)有功能上的區(qū)別。唯一的區(qū)別是,在基本正則表達(dá)式中,元字符?,+,{,|,(和)被解釋為文字字符。為了在使用基本正則表達(dá)式時(shí)保持元字符的特殊含義,必須使用反斜杠()對(duì)字符進(jìn)行轉(zhuǎn)義。稍后我們將解釋這些和其他元字符的含義。

通常,您應(yīng)始終將正則表達(dá)式括在單引號(hào)中,以避免shell解釋和擴(kuò)展元字符。

文字匹配

grep命令最基本的用法是在文件中搜索文字字符或一系列字符。例如,要在/ etc / passwd文件中顯示所有包含字符串“ bash”的行,您可以運(yùn)行以下命令:

[linuxidc@localhost www.linuxidc.com]$ grep bash /etc/passwd

輸出應(yīng)如下所示:

root:x:0:0:root:/root:/bin/bash

linuxidc:x:1000:1000:linuxidc:/home/linuxidc:/bin/bash

在此示例中,字符串“ bash”是由四個(gè)文字字符組成的基本正則表達(dá)式。 這告訴grep搜索帶有緊隨其后的“ a”,“ s”和“ h”的字符串“ b”。

缺省情況下,grep命令區(qū)分大小寫(xiě)。 這意味著將大寫(xiě)和小寫(xiě)字符視為不同的字符。 要在搜索時(shí)忽略大小寫(xiě),請(qǐng)使用-i選項(xiàng)(或--ignore-case)。

請(qǐng)務(wù)必注意,grep會(huì)將搜索模式作為字符串而不是單詞來(lái)查找。 因此,如果您要搜索“ gnu”,則grep還將打印“ gnu”嵌入較大字詞(例如“ cygnus”或“ magnum”)的行。

如果搜索字符串包含空格,則需要將其用單引號(hào)或雙引號(hào)引起來(lái):

$grep “Gnome Display Manager” /etc/passwd

錨定Anchoring

Anchoring是元字符,可讓您指定必須在該行中找到匹配項(xiàng)的位置。

^(脫字符號(hào))符號(hào)與一行開(kāi)頭的空字符串匹配。 在以下示例中,僅當(dāng)字符串“ linux”出現(xiàn)在行的開(kāi)頭時(shí)才匹配。

$grep ‘^linux’ file.txt

$(美元)符號(hào)與行首的空字符串匹配。 要查找以字符串“ linux”結(jié)尾的行,可以使用:

$grep ‘linux$’ file.txt

您還可以使用兩個(gè)錨點(diǎn)構(gòu)造一個(gè)正則表達(dá)式。 例如,要查找僅包含“ linux”的行,請(qǐng)運(yùn)行:

$grep ‘^linux$’ file.txt

另一個(gè)有用的示例是匹配所有空行的^ $模式。

匹配單個(gè)字符

。(點(diǎn))符號(hào)是與任何單個(gè)字符匹配的元字符。 例如,要匹配以“ kan”開(kāi)頭,然后有兩個(gè)字符并以字符串“ roo”結(jié)尾的任何內(nèi)容,則可以使用以下模式:

$grep ‘kan..roo’ file.txt

括號(hào)表達(dá)式

方括號(hào)表達(dá)式允許將一組字符括在方括號(hào)[]中來(lái)匹配一組字符。 例如,找到包含“ accept”或“ accent”的行,可以使用以下表達(dá)式:

$grep ‘a(chǎn)cce[np]t’ file.txt

如果方括號(hào)內(nèi)的第一個(gè)字符是插入符號(hào)^,則它匹配方括號(hào)中未包含的任何單個(gè)字符。 以下模式將匹配以“ co”開(kāi)頭的字符串的任意組合,后接除“ l”之后為“ la”的任何字母(例如“ coca”,“ cobalt”等),但不匹配包含“ cola”的行 ”:

$grep ‘co[^l]a’ file.txt

您可以在方括號(hào)內(nèi)指定一系列字符,而不是一個(gè)一個(gè)地放置字符。 通過(guò)指定以連字符分隔的范圍的第一個(gè)和最后一個(gè)字符來(lái)構(gòu)造范圍表達(dá)式。 例如,[a-a]等效于[abcde],[1-3]等效于[123]。

以下表達(dá)式匹配以大寫(xiě)字母開(kāi)頭的每一行:

$grep ‘^[A-Z]’ file.txt

grep還支持括號(hào)中預(yù)定義的字符類。 下表顯示了一些最常見(jiàn)的字符類:

QuantifierCharacter Classes

[:alnum:]字母數(shù)字字符。

[:alpha:]字母字符。

[:blank:]空格和制表符。

[:digit:]數(shù)字。

[:lower:]小寫(xiě)字母。

[:upper:]大寫(xiě)字母。

有關(guān)所有字符類別的完整列表,請(qǐng)參閱Grep手冊(cè)。

量詞

量詞Quantifier允許您指定要出現(xiàn)的匹配項(xiàng)必須出現(xiàn)的項(xiàng)數(shù)。 下表顯示了GNU grep支持的量詞:

Quantifier描述

*匹配上一項(xiàng)零次或多次。

?匹配上一項(xiàng)零或一次。

+將上一項(xiàng)匹配一次或多次。

{n}將前一項(xiàng)精確匹配n次。

{n,}至少匹配n個(gè)項(xiàng)目。

{,m}最多匹配m次以上項(xiàng)。

{n,m}將前一項(xiàng)匹配n至m次。

*(星號(hào))字符與前面的項(xiàng)目匹配零次或多次。 以下將匹配“right”,“sright”,“ssright”等等。

$grep ‘s*right’

下面是更高級(jí)的模式,它匹配所有以大寫(xiě)字母開(kāi)頭,以句點(diǎn)或逗號(hào)結(jié)尾的行。 .* 正則表達(dá)式匹配任意數(shù)量的任何字符:

$grep -E ‘^[A-Z].*[。,]$’ file.txt

? (問(wèn)號(hào))字符使前一項(xiàng)為可選,并且只能匹配一次。 以下將同時(shí)匹配“bright”和“right”。 ? 字符以反斜杠轉(zhuǎn)義,因?yàn)槲覀兪褂玫氖腔菊齽t表達(dá)式:

$grep ‘b?right’ file.txt

下面是使用擴(kuò)展正則表達(dá)式的同一個(gè)正則表達(dá)式:

$grep -E ‘b?right’ file.txt

+(加號(hào))字符與前面的項(xiàng)目匹配一次或多次。 以下將匹配“sright”和“ssright”,但不匹配“right”:

$grep -E ‘s+right’ file.txt

大括號(hào)字符{}使您可以指定確切的數(shù)字,上限或下限或發(fā)生匹配必須發(fā)生的范圍。

以下內(nèi)容匹配3到9位之間的所有整數(shù):

$grep -E ‘[[:digit:]]{3,9}’ file.txt

交替Alternation

交替是一個(gè)簡(jiǎn)單的“或”。替換操作符| (pipe)允許您指定不同的可能匹配,可以是文字字符串或表達(dá)式集。該操作符在所有正則表達(dá)式操作符中優(yōu)先級(jí)最低。

在下面的例子中,我們搜索Nginx日志錯(cuò)誤文件中出現(xiàn)的所有單詞fatal, error和critical:

$grep ‘fatal|error|critical’ /var/log/nginx/error.log

如果使用擴(kuò)展正則表達(dá)式,則不應(yīng)轉(zhuǎn)義運(yùn)算符|,如下所示:

$grep -E ‘fatal|error|critical’ /var/log/nginx/error.log

分組

分組是正則表達(dá)式的一項(xiàng)功能,可讓您將模式分組在一起并將其作為一項(xiàng)引用。 使用括號(hào)()創(chuàng)建組。

使用基本正則表達(dá)式時(shí),必須用反斜杠()對(duì)括號(hào)進(jìn)行轉(zhuǎn)義。

下面的示例同時(shí)匹配“ fearless”和“ less”。 ? 量詞使(fear)組成為可選的:

$grep -E ‘(fear)?less’ file.txt

反斜杠特殊表達(dá)式

GNU grep包含幾個(gè)元字符,由反斜杠和常規(guī)字符組成。 下表顯示了一些最常見(jiàn)的特殊反斜杠表達(dá)式:

ExpressionDescription

單詞鎖定符

《在單詞開(kāi)頭匹配一個(gè)空字符串。

》在單詞末尾匹配一個(gè)空字符串。

w匹配一個(gè)單詞。

s匹配一個(gè)空格。

以下模式將匹配單獨(dú)的單詞“ abject”和“ object”。 如果嵌入較大的單詞,則不會(huì)匹配這些單詞:

$grep ‘[ao]bject’ file.txt

總結(jié)

正則表達(dá)式用于文本編輯器,編程語(yǔ)言和命令行工具,例如grep,sed和awk。 在搜索文本文件,編寫(xiě)腳本或過(guò)濾命令輸出時(shí),了解如何構(gòu)造正則表達(dá)式將非常有幫助。

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11292

    瀏覽量

    209326
  • GNU
    GNU
    +關(guān)注

    關(guān)注

    0

    文章

    143

    瀏覽量

    17492
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    詳解nginx正則表達(dá)式

    前言,我這里驗(yàn)證的nginx-v1.23.2單機(jī)環(huán)境下的nginx正則表達(dá)式、location路徑匹配規(guī)則和優(yōu)先級(jí)。
    的頭像 發(fā)表于 12-03 09:59 ?145次閱讀
    詳解nginx<b class='flag-5'>中</b>的<b class='flag-5'>正則表達(dá)式</b>

    Verilog表達(dá)式的位寬確定規(guī)則

    很多時(shí)候,Verilog中表達(dá)式的位寬都是被隱式確定的,即使你自己設(shè)計(jì)了位寬,它也是根據(jù)規(guī)則先確定位寬后,再擴(kuò)展到你的設(shè)計(jì)位寬,這常常會(huì)導(dǎo)致結(jié)果產(chǎn)生意想不到的錯(cuò)誤。
    的頭像 發(fā)表于 10-22 15:41 ?443次閱讀
    Verilog<b class='flag-5'>表達(dá)式</b>的位寬確定規(guī)則

    nginx正則表達(dá)式和location路徑匹配指南

    前言,我這里驗(yàn)證的nginx-v1.23.2單機(jī)環(huán)境下的nginx正則表達(dá)式、location路徑匹配規(guī)則和優(yōu)先級(jí)。
    的頭像 發(fā)表于 09-29 16:02 ?716次閱讀
    nginx<b class='flag-5'>中</b>的<b class='flag-5'>正則表達(dá)式</b>和location路徑匹配指南

    求助,以下恒流源電路Io的計(jì)算表達(dá)式怎么計(jì)算?

    這個(gè)恒流源電路Io的計(jì)算表達(dá)式怎么計(jì)算,求給出詳細(xì)計(jì)算過(guò)程
    發(fā)表于 08-22 08:16

    TestStand表達(dá)式中常用的語(yǔ)法規(guī)則和運(yùn)算符使用

    TestStand也有自己的語(yǔ)言嘛?在回答這個(gè)問(wèn)題之前大家可以想一下在使用TestStand時(shí)有一個(gè)和語(yǔ)言密切相關(guān)的屬性。沒(méi)錯(cuò)那就是表達(dá)式(Expressions),在這篇文章,小編將以Q&A的方式來(lái)帶著大家來(lái)理解并熟悉TestStand
    的頭像 發(fā)表于 08-15 18:10 ?1351次閱讀
    TestStand<b class='flag-5'>表達(dá)式</b>中常用的語(yǔ)法規(guī)則和運(yùn)算符使用

    Java表達(dá)式引擎選型調(diào)研分析

    1 簡(jiǎn)介 我們項(xiàng)目組主要負(fù)責(zé)面向企業(yè)客戶的業(yè)務(wù)系統(tǒng), 企業(yè)的需求往往是多樣化且復(fù)雜的,對(duì)接不同企業(yè)時(shí)會(huì)有不同的定制化的業(yè)務(wù)模型和流程。 我們?cè)跇I(yè)務(wù)系統(tǒng) 使用表達(dá)式引擎,集中配置管理業(yè)務(wù)規(guī)則,并實(shí)現(xiàn)
    的頭像 發(fā)表于 08-15 14:25 ?341次閱讀
    Java<b class='flag-5'>表達(dá)式</b>引擎選型調(diào)研分析

    鴻蒙原生應(yīng)用元服務(wù)開(kāi)發(fā)-倉(cāng)頡基本概念表達(dá)式(二)

    。for-in 表達(dá)式的基本形式為: for (迭代變量 in 序列) { 循環(huán)體 } 其中“循環(huán)體”是一個(gè)代碼塊?!暗兞俊笔菃蝹€(gè)標(biāo)識(shí)符或由多個(gè)標(biāo)識(shí)符構(gòu)成的元組,用于綁定每輪遍歷由迭代器指向的數(shù)據(jù),可以
    發(fā)表于 08-09 14:26

    鴻蒙原生應(yīng)用元服務(wù)開(kāi)發(fā)-倉(cāng)頡基本概念表達(dá)式(一)

    實(shí)參等。此外,因?yàn)閭}(cāng)頡是強(qiáng)類型的編程語(yǔ)言,所以倉(cāng)頡表達(dá)式不僅可求值,還有確定的類型。 倉(cāng)頡編程語(yǔ)言的各種表達(dá)式將在后續(xù)章節(jié)逐一介紹,本節(jié)介紹最常用的條件表達(dá)式、循環(huán)
    發(fā)表于 08-08 10:27

    求助,有關(guān)表達(dá)式選項(xiàng)卡(ADS)的問(wèn)題求解

    你好。 我看不到表達(dá)式選項(xiàng)卡的某些變量值。 數(shù)組的大小顯然是 256,但我最多只能看到 100。 請(qǐng)問(wèn)問(wèn)題出在哪里? 謝謝。
    發(fā)表于 06-03 06:23

    mapgis屬性篩選表達(dá)式

    篇文章,我們將詳細(xì)討論MapGIS的屬性篩選表達(dá)式,包括語(yǔ)法、操作符和函數(shù)等。 屬性篩選表達(dá)式是一種在MapGIS中用于指定要素選擇條件的代碼。它由一組操作符、函數(shù)和屬性字段組成,用
    的頭像 發(fā)表于 02-25 10:58 ?1612次閱讀

    西門(mén)子博途的算術(shù)表達(dá)式

    算術(shù)表達(dá)式既可以是一個(gè)數(shù)字值,也可以是由帶有算術(shù)運(yùn)算符的兩個(gè)值或表達(dá)式組合而成。 算術(shù)運(yùn)算符可以處理當(dāng)前 CPU 所支持的各種數(shù)據(jù)類型。如果在該運(yùn)算中有 2 個(gè)操作數(shù),那么可根據(jù)以下條件來(lái)確定結(jié)果的數(shù)據(jù)類型。
    的頭像 發(fā)表于 01-24 11:36 ?1000次閱讀

    你還不會(huì)gvim正則表達(dá)式?一文搞懂!

    gvim正則表達(dá)式常在命令行模式下使用,一般用于文本文件字符串的替換、刪除等操作。
    的頭像 發(fā)表于 01-19 16:47 ?1169次閱讀

    rs觸發(fā)器的邏輯表達(dá)式

    邏輯表達(dá)式是描述邏輯關(guān)系的符號(hào)表示,可以用于定義和描述各種電路和邏輯操作。在邏輯電路,RS觸發(fā)器是一種基本的存儲(chǔ)器元件,也被稱為鎖存器。 RS觸發(fā)器是由兩個(gè)與門(mén)組成的,其輸出互相連接,形成一個(gè)反饋
    的頭像 發(fā)表于 01-12 14:09 ?3110次閱讀

    Linux常用命令自學(xué)手冊(cè)》+Linux簡(jiǎn)單指令筆記

    --verbose:顯示復(fù)制過(guò)程詳細(xì)信息。 此外,cp命令還有其他選項(xiàng),如-a、-b、-d、-l等。 grep命令: grep命令是一種強(qiáng)大的文本搜索工具,能夠使用
    發(fā)表于 01-05 08:44

    更快的tsv解析代碼分享

    使用正則解析的正則表達(dá)式很簡(jiǎn)單, 這里直接給代碼, 為了避免重復(fù)編譯正則表達(dá)式和重新分配內(nèi)存報(bào)錯(cuò)結(jié)果列表, 這里將她們作為參數(shù)傳給解析函數(shù).
    的頭像 發(fā)表于 12-29 09:45 ?426次閱讀
    更快的tsv解析代碼分享
    RM新时代网站-首页