linux命令find,grep,正則表達式


linux 命令

find

根據文件的名稱或者屬性查找文件

語法格式:
    find [查找范圍] [參數]

參數:
    -name : 按照文件的名字查找文件
        * : 通配符
    -iname : 按照文件的名字查找(忽略大小寫)
    -size : 按照文件的大小查找文件
        + : 大於
        - : 小於
        沒符號 : 等於

    -mtime : 按照修改時間去查詢
        + (可以省略) : n天以前
        -           : n天以后
    -atime:
    -ctime:

    -user : 按照用戶的屬主查詢
    -group : 按照用戶的屬組查詢
    -type : 按照文件的類型查詢
        f : 普通文件
        d :  文件夾
        l : 鏈接文件
        s : 套接字文件
        p : 管道文件
        c : 字符文件
        b : 磁盤文件
  
    -prem : 按照文件的權限查詢
    -inum : 按照index node號碼查詢
      
       -a : 並且(可以省略,默認是並且)
       -o : 或者
       -maxdepth : 查詢的目錄深度(必須放置於第一個參數位)

       -exec : 將find處理好的結果交給其他命令繼續處理

知識儲備:
    dd : 生成文件
        if    : 從什么地方讀
        of    : 寫入到什么文件
        bs    :每次寫入多少內容
        count : 寫入多少次

案例:
    案例1:查詢/etc目錄下hosts文件
       [root@localhost ~]#  find /etc -name 'hosts'
       /etc/hosts
    案例2:查詢/etc目錄下名稱中包含hosts文件
       [root@localhost ~]#  find /etc -name '*hosts*'
       /etc/selinux/targeted/active/modules/100/denyhosts
       /etc/hosts
       /etc/hosts.allow
       /etc/hosts.deny
    案例3:要求把/etc目錄下.所有的普通文件打包壓縮到/tmp目錄
       [root@localhost ~]# tar -caPf /tmp/etcv2.tar.gz `find /etc/ -type f | xargs`
 
知識儲備:
    | : 前面一個命令的結果交給后面的一個命令處理
    xargs : 把處理的文本變成空格分割的一行
    `` : 提前執行命令,然后將結果交給其他命令處理      

grep

linux三劍客之一,文本過濾器(根據文本內容過濾文件)

語法格式:
    grep [參數] [匹配規則] [操作對象]

參數:
    -n : 過濾文本時,將過濾出來的內容在文件內的行號顯示出來
    -A : 匹配成功之后,將匹配行的后n行顯示出來
    -B : 匹配成功之后,將匹配行的前n行顯示出來
    -C : 匹配成功之后,將匹配行的前后各n行顯示出來
    -c : 只顯示匹配成功的行數
    -o : 只顯示匹配成功的內容
    -v : 反向過濾
    -q : 靜默輸出
    -i : 忽略大小寫
    -l : 匹配成功之后,將文本的名稱打印出來
    -R|-r : 遞歸匹配

    -E : 使用擴展正則 等價於 egrep

知識儲備:
    $? : 上一行命令執行的結果.0代表執行成功,其他數字代表執行失敗
    wc : 匹配行數
        -l : 打印匹配行數
        -c : 打印匹配的字節數


在/etc目錄下,有多少個文件包含root
    [root@localhost ~]# grep -rl 'root' /etc/ | wc -l
    
    

正則表達式

正則表達式的分類(grep)
    1.普通正則表達式
    2.擴展正則表達式

普通正則表達式

    ^ : 以某字符開頭
    $ : 以某字符結尾
    . : 匹配除換行符之外的任意單個字符
    * : 匹配前導字符的任意個數
    [] : 某組字符串的任意一個字符
    [^] : 取反
    [a-z] : 匹配小寫字母
    [A-Z] : 匹配大寫字母
    [a-zA-Z] : 匹配字母
    [0-9] : 匹配數字
    \ : 取消轉義
    () : 分組
        \n : 代表第n個分組

擴展正則
    {} : 匹配的次數
        {n} : 匹配n次
        {n,} : 至少匹配n次
        {n,m} : 至少匹配 n 到 m 次
        {,m} : 最多匹配m次
     + : 匹配至少有一個前導字符
     ? : 匹配零個或一個前導字符
     | : 或

案例:
    案例1:在/etc/passwd文件中,匹配以ftp開頭的行
        grep '^ftp' /etc/passwd
    
    案例2:在/etc/passswd文件中,匹配以bash結尾的行
        grep 'bash$' /etc/passwd

    案例3:匹配本機中有哪些ip
        ip a | grep -oE '([0-9]{1.3}\.){3}[0-9]{1,3}'

    案例4:要求將/etc/fstab中的去掉包含 # 開頭的行, 且要求 # 后至少有一個空格
        grep -vE '^#\ +' /etc/fstab
  
    案例5:找出文件中至少有一個空格的行
        grep -E '\ +' xxx

    案例6:將nginx.conf 文件中以#開頭的行和空行,全部刪除
        grep -vE '^\ *#|^$' /etc/nginx/nginx.conf
     


免責聲明!

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



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