grep專題

grep -R --include="*.cpp" key dir【指定文件的擴展名】html

上述命令的含義:linux

在dir目錄下遞歸查找全部.cpp文件中的關鍵字key正則表達式

grep -r magic /usr/src  #顯示/usr/src目錄下的文件(包含子目錄)包含magic的行【不指定文件擴展名】express

 

find / -type f -name "*xml"|xargs grep "zh_CN" 2>/dev/null
(1)在/目錄下查找文件名以xml結尾的文件
(2)查看每一個符合條件的行記錄
(3)grep過程的錯誤信息不顯示。錯誤提示信息示例:grep: n3U: 沒有那個文件或目錄bash

 

好比想在gcc手冊裏找-o選項對應的解釋,若是man gcc | grep -o,grep會把-o當作本身的命令選項,是得不到正確結果的。
若是想獲得正確結果,把待查的-o擴展成*-o就好了,不過這時須要給grep加上-E選項,因此最終的實例爲:session

man gcc |grep -E *-o

 

使用 -l 選項能夠只顯示文件名ide

[root@10-25-174-68 logs]# grep -l root /etc/*
grep: /etc/acpi: 是一個目錄
/etc/aliases
/etc/aliases.db
grep: /etc/alternatives: 是一個目錄
/etc/anacrontab
grep: /etc/audisp: 是一個目錄
grep: /etc/audit: 是一個目錄
grep: /etc/avahi: 是一個目錄
[root@10-25-174-68 logs]# grep -lR root /etc/*
/etc/aliases
/etc/aliases.db
/etc/alternatives/ld
/etc/alternatives/mta
/etc/alternatives/mta-mailq
/etc/alternatives/mta-newaliases
/etc/alternatives/mta-sendmail
/etc/alternatives/libnssckbi.so.x86_64
/etc/anacrontab
/etc/audit/auditd.conf
/etc/bash_completion.d/yum
/etc/bash_completion.d/yummain.py
/etc/cron.d/0hourly
/etc/crontab


你也能夠逆轉輸出;使用 -L 選項來輸出那些不匹配的文件的文件名:ui

[root@10-25-174-68 logs]# grep -LR root /etc/*
/etc/acpi/actions/power.sh
/etc/acpi/events/powerconf
/etc/acpi/events/videoconf
/etc/adjtime
/etc/alternatives/mta-pam

power.sh中沒有包括root字符串url

[root@10-25-174-68 logs]# more /etc/acpi/actions/power.sh
#!/bin/sh

PATH=/sbin:/bin:/usr/bin

# Check session status using systemd
session_ids=$(systemd-loginctl list-sessions 2>/dev/null | awk '{print $1}')
for session in ${session_ids} ; do
        session_status=$(systemd-loginctl session-status ${session})
        echo "${session_status}" | grep -e '\(Active: yes\|State: active\)' &> /dev/null &&
                echo "${session_status}" | grep -e '\(gnome-settings-daemon\|kded4\|xfce4-power-manager\)' &> /dev/null &&
 exit 0
done

# Get the ID of the first active X11 session: using ConsoleKit
uid_session=$(
ck-list-sessions 2>/dev/null | \
awk '
/^Session[0-9]+:$/ { uid = active = x11 = "" ; next }
{ gsub(/'\''/, "", $3) }
$1 == "unix-user" { uid = $3 }
$1 == "active" { active = $3 }
$1 == "x11-display" { x11 = $3 }
active == "TRUE" && x11 != "" {
        print uid
        exit
}')

# Check that there is a power manager, otherwise shut down.
[ "$uid_session" ] &&
ps axo uid,cmd | \
awk '
    $1 == '$uid_session' &&
        ($2 ~ /gnome-power-manager/ || $2 ~ /kpowersave/ ||
         $2 ~ /xfce4-power-manager/ || $2 ~ /\/usr\/libexec\/gnome-settings-daemon/ ||
         $2 ~ /kded4/ || $3 ~ /guidance-power-manager/) \
                { found = 1; exit }
    END { exit !found }
' ||
  shutdown -h now

[root@10-25-174-68 logs]# 

 






在使用linux時,常常須要進行文件查找。其中查找的命令主要有find和grep。兩個命令是有區的。spa

  區別:(1)find命令是根據文件的屬性進行查找,如文件名,文件大小,全部者,所屬組,是否爲空,訪問時間,修改時間等。 

               (2)grep是根據文件的內容進行查找,會對文件的每一行按照給定的模式(patter)進行匹配查找。

  一.find命令

    基本格式:find  path expression

    1.按照文件名查找

    (1)find / -name httpd.conf  #在根目錄下查找文件httpd.conf,表示在整個硬盤查找
    (2)find /etc -name httpd.conf  #在/etc目錄下文件httpd.conf
    (3)find /etc -name '*srm*'  #使用通配符*(0或者任意多個)。表示在/etc目錄下查找文件名中含有字符串‘srm’的文件
    (4)find . -name 'srm*'   #表示當前目錄下查找文件名開頭是字符串‘srm’的文件

    2.按照文件特徵查找     

    (1)find / -amin -10   # 查找在系統中最後10分鐘訪問的文件(access time)
    (2)find / -atime -2   # 查找在系統中最後48小時訪問的文件
    (3)find / -empty   # 查找在系統中爲空的文件或者文件夾
    (4)find / -group cat   # 查找在系統中屬於 group爲cat的文件
    (5)find / -mmin -5   # 查找在系統中最後5分鐘裏修改過的文件(modify time)
    (6)find / -mtime -1   #查找在系統中最後24小時裏修改過的文件
    (7)find / -user fred   #查找在系統中屬於fred這個用戶的文件
    (8)find / -size +10000c  #查找出大於10000000字節的文件(c:字節,w:雙字,k:KB,M:MB,G:GB)
    (9)find / -size -1000k   #查找出小於1000KB的文件

    3.使用混合查找方式查找文件

    參數有: !,-and(-a),-or(-o)。

    (1)find /tmp -size +10000c -and -mtime +2   #在/tmp目錄下查找大於10000字節並在最後2分鐘內修改的文件
         (2)find / -user fred -or -user george   #在/目錄下查找用戶是fred或者george的文件文件
         (3)find /tmp ! -user panda  #在/tmp目錄中查找全部不屬於panda用戶的文件
        

  2、grep命令

     基本格式:find  expression

     1.主要參數

    [options]主要參數:
    -c:只輸出匹配行的計數。
    -i:不區分大小寫
    -h:查詢多文件時不顯示文件名。
    -l:查詢多文件時只輸出包含匹配字符的文件名
    -n:顯示匹配行及行號。
    -s:不顯示不存在或無匹配文本的錯誤信息。
    -v:顯示不包含匹配文本的全部行。

    pattern正則表達式主要參數:
    \: 忽略正則表達式中特殊字符的原有含義。
    ^:匹配正則表達式的開始行。
    $: 匹配正則表達式的結束行。
    \<:從匹配正則表達 式的行開始。
    \>:到匹配正則表達式的行結束。
    [ ]:單個字符,如[A]即A符合要求 。
    [ - ]:範圍,如[A-Z],即A、B、C一直到Z都符合要求 。
    .:全部的單個字符。
    * :有字符,長度能夠爲0。

    2.實例  

  (1)grep 'test' d*  #顯示全部以d開頭的文件中包含 test的行
  (2)grep ‘test’ aa bb cc    #顯示在aa,bb,cc文件中包含test的行
  (3)grep ‘[a-z]\{5\}’ aa   #顯示全部包含每行字符串至少有5個連續小寫字符的字符串的行
  (4)grep magic /usr/src  #顯示/usr/src目錄下的文件(不含子目錄)包含magic的行
  (5)grep -r magic /usr/src  #顯示/usr/src目錄下的文件(包含子目錄)包含magic的行

  (6)grep -w pattern files :只匹配整個單詞,而不是字符串的一部分(如匹配’magic’,而不是’magical’),

http://www.cnblogs.com/zhangmo/p/3571735.html

相關文章
相關標籤/搜索