Linux 內容查找匹配命令


高頻率命令

  1. grep

    適合單純的查找或匹配文本

    語法

    grep [-abcEFGhHilLnqrsvVwxy][-A<顯示列數>][-B<顯示列數>][-C<顯示列數>][-d<進行動作>][-e<范本樣式>][-f<范本文件>][--help][范本樣式][文件或目錄...]
    

    參數說明

    • -a 或 --text : 不要忽略二進制的數據。
    • -A<顯示行數> 或 --after-context=<顯示行數> : 除了顯示符合范本樣式的那一列之外,並顯示該行之后的內容。
    • -b 或 --byte-offset : 在顯示符合樣式的那一行之前,標示出該行第一個字符的編號。
    • -B<顯示行數> 或 --before-context=<顯示行數> : 除了顯示符合樣式的那一行之外,並顯示該行之前的內容。
    • -c 或 --count : 計算符合樣式的列數。
    • -C<顯示行數> 或 --context=<顯示行數>或-<顯示行數> : 除了顯示符合樣式的那一行之外,並顯示該行之前后的內容。
    • -d <動作> 或 --directories=<動作> : 當指定要查找的是目錄而非文件時,必須使用這項參數,否則grep指令將回報信息並停止動作。
    • -e<范本樣式> 或 --regexp=<范本樣式> : 指定字符串做為查找文件內容的樣式。
    • -E 或 --extended-regexp : 將樣式為延伸的正則表達式來使用。
    • -f<規則文件> 或 --file=<規則文件> : 指定規則文件,其內容含有一個或多個規則樣式,讓grep查找符合規則條件的文件內容,格式為每行一個規則樣式。
    • -F 或 --fixed-regexp : 將樣式視為固定字符串的列表。
    • -G 或 --basic-regexp : 將樣式視為普通的表示法來使用。
    • -h 或 --no-filename : 在顯示符合樣式的那一行之前,不標示該行所屬的文件名稱。
    • -H 或 --with-filename : 在顯示符合樣式的那一行之前,表示該行所屬的文件名稱。
    • -i 或 --ignore-case : 忽略字符大小寫的差別。
    • -l 或 --file-with-matches : 列出文件內容符合指定的樣式的文件名稱。
    • -L 或 --files-without-match : 列出文件內容不符合指定的樣式的文件名稱。
    • -n 或 --line-number : 在顯示符合樣式的那一行之前,標示出該行的列數編號。
    • -o 或 --only-matching : 只顯示匹配PATTERN 部分。
    • -q 或 --quiet或--silent : 不顯示任何信息。
    • -r 或 --recursive : 此參數的效果和指定"-d recurse"參數相同。
    • -s 或 --no-messages : 不顯示錯誤信息。
    • -v 或 --invert-match : 顯示不包含匹配文本的所有行。
    • -V 或 --version : 顯示版本信息。
    • -w 或 --word-regexp : 只顯示全字符合的列。
    • -x --line-regexp : 只顯示全列符合的列。
    • -y : 此參數的效果和指定"-i"參數相同。

    用法1

    # 在當前目錄中,查找后綴有 file 字樣的文件中包含 test 字符串的行
    grep test *file
    

    用法2

    # 管道用法
    # 查找log.txt文件中包含test的行,且顯示該行之后2行的內容
    cat log.txt | grep test -A 2
    

    用法3

    # 查找文件名中包含 log 的文件中不包含test 的行
    grep -v test *log*
    
  2. sed

    適合編輯匹配到的文本

    語法

    sed [-hnV][-e<script>][-f<script文件>][文本文件]
    

    參數說明

    • -e<script>或--expression=<script> 以選項中指定的script來處理輸入的文本文件。
    • -f<script文件>或--file=<script文件> 以選項中指定的script文件來處理輸入的文本文件。
    • -h或--help 顯示幫助。
    • -n或--quiet或--silent 僅顯示script處理后的結果。
    • -V或--version 顯示版本信息。

    動作說明

    • a :新增, a 的后面可以接字串,而這些字串會在新的一行出現(目前的下一行)~
    • c :取代, c 的后面可以接字串,這些字串可以取代 n1,n2 之間的行!
    • d :刪除,因為是刪除啊,所以 d 后面通常不接任何咚咚;
    • i :插入, i 的后面可以接字串,而這些字串會在新的一行出現(目前的上一行);
    • p :打印,亦即將某個選擇的數據印出。通常 p 會與參數 sed -n 一起運行~
    • s :取代,可以直接進行取代的工作哩!通常這個 s 的動作可以搭配正規表示法!例如 1,20s/old/new/g 就是啦!

    用法

    # 在test文件的第四行后添加other
    sed -e '4a other' test
    
    # 將 test.log 的內容列出並且列印行號,同時,將第 2~5 行刪除
    nl test.og | sed '2,5d'
    
    # 將第2-5行的內容取代成為 this is test
    nl test.log | sed '2,5c this is test'
    
    # 數據的搜尋並替換
    sed 's/要被取代的字串/新的字串/g'
    

    sed 的 -i 選項可以直接修改文件內容,對處理大文件很有用

    # 利用 sed 將 test.txt 內每一行結尾若為 . 則換成 !
    sed -i 's/\.$/\!/g' test.txt
    
  3. awk

    適合格式化文本,對文本進行較復雜格式處理

    語法

    awk [選項參數] 'script' var=value file(s)
    或
    awk [選項參數] -f scriptfile var=value file(s)
    

    參數說明

    • -F fs or --field-separator fs
      指定輸入文件折分隔符,fs是一個字符串或者是一個正則表達式,如-F:。

    • -v var=value or --asign var=value
      賦值一個用戶定義變量。

    • -f scripfile or --file scriptfile
      從腳本文件中讀取awk命令。

    • -mf nnn and -mr nnn
      對nnn值設置內在限制,-mf選項限制分配給nnn的最大塊數目;-mr選項限制記錄的最大數目。這兩個功能是Bell實驗室版awk的擴展功能,在標准awk中不適用。

    • -W compact or --compat, -W traditional or --traditional
      在兼容模式下運行awk。所以gawk的行為和標准的awk完全一樣,所有的awk擴展都被忽略。

    • -W copyleft or --copyleft, -W copyright or --copyright
      打印簡短的版權信息。

    • -W help or --help, -W usage or --usage
      打印全部awk選項和每個選項的簡短說明。

    • -W lint or --lint
      打印不能向傳統unix平台移植的結構的警告。

    • -W lint-old or --lint-old
      打印關於不能向傳統unix平台移植的結構的警告。

    • -W posix
      打開兼容模式。但有以下限制,不識別:/x、函數關鍵字、func、換碼序列以及當fs是一個空格時,將新行作為一個域分隔符;操作符**和**=不能代替=;fflush無效。

    • -W re-interval or --re-inerval
      允許間隔正則表達式的使用,參考(grep中的Posix字符類),如括號表達式[[:alpha:]]。

    • -W source program-text or --source program-text
      使用program-text作為源代碼,可與-f命令混用。

    • -W version or --version
      打印bug報告信息的版本。

    用法1

    # 每行按空格或TAB分割,輸出文本中的1、4項
    awk '{print $1,$4}' test.txt
    

    用法2

    # 使用","分割
    awk -F, '{print $1,$2}' test.txt
    

    用法3

    # 使用正則,~ 表示模式開始,// 中是模式
    # 輸出第二列包含 "test",並打印第二列與第四列
    $ awk '$2 ~ /test/ {print $2,$4}' test.txt
    
  4. 內容查看命令

    語法

    # 打印文件內容到標准輸出設備上
    cat [-AbeEnstTuv] [--help] [--version] fileName
    
    # 類似 cat ,不過會以一頁一頁的形式顯示
    more [-dlfpcsu] [-num] [+/pattern] [+linenum] [fileNames..]
    
    # 與 more 類似,但使用 less 可以隨意瀏覽文件
    less [參數] 文件
    
    # 可用於查看文件的開頭部分的內容,有一個常用的參數 -n 用於顯示行數
    head [參數] [文件]
    
    # 可用於查看文件的內容,有一個常用的參數 -f 常用於查閱正在改變的日志文件
    tail [參數] [文件]
    
  5. wc

    用於計算字數

    語法

    wc [-clw][--help][--version][文件...]
    

    參數

    • -c或--bytes或--chars 只顯示Bytes數。
    • -l或--lines 只顯示行數。
    • -w或--words 只顯示字數。
    • --help 在線幫助。
    • --version 顯示版本信息。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM