• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-159  評(píng)論-223  文章-30  trackbacks-0
            方法1:使用find和xargs命令
                 find dir | xargs grep str,dir是指某個(gè)目錄
                 find file | xargs grep str,file是指某個(gè)文件
               注意:這種方法,會(huì)遞歸搜索子目錄

            方法2:直接使用grep命令
                 grep str dir/*,dir是指某個(gè)目錄,但不遞歸搜索其子目錄
                 grep -r str dir/*,使用-r選項(xiàng),遞歸搜索其子目錄
                 grep str file,file是指某個(gè)文件

            方法3:綜合以上兩種,寫一個(gè)shell腳本,代碼如下 
             1#! /bin/bash
             2# findstr.sh   
             3
             4if [ $# -lt "2" ]; then
             5   echo "Usage: `basename $0` path name [option]"
             6   exit 1
             7fi   
             8
             9path=$1
            10name=$2  
            11shift 
            12shift   
            13
            14for option in "$@"
            15do
            16   case $option in
            17   -r) dir_op="-r"
            18   ;;
            19   -i) lu_op="-i"
            20   ;;
            21   *if [ -"$option" ]; then
            22         echo "invalid option"
            23         exit 1
            24       fi
            25   ;;
            26  esac
            27done    
            28
            29grep_str_of_file()
            30{
            31     file=$1
            32     str=$2
            33     out=$(grep -n $lu_op "$str" "$file")
            34     if [ -"$out" -"$file" != "$0" ]; then
            35        echo "$file: $out"
            36     fi
            37}    
            38
            39find_str()
            40{
            41  if [ -"$1" ]; then
            42     for file in $1/*
            43      do
            44        if [ "$dir_op" = "-r" --"$file" ]; then
            45            find_str $file $2
            46        elif [ -"$file" ]; then
            47           grep_str_of_file $file $2
            48        fi
            49     done
            50 elif [ -"$1" ]; then
            51   grep_str_of_file $1 $2    
            52 fi
            53}  
            54
            55find_str $path $name
              這樣一來(lái),不管$1參數(shù)是目錄還是文件,都能處理,使用示例如下:
                findstr /usr/include main          不遞歸搜索子目錄,大小寫敏感
                findstr /usr/include main -i       不遞歸搜索子目錄,忽略大小寫
                findstr /usr/include main -r       遞歸搜索子目錄,大小寫敏感
                findstr /usr/include main -r  -i   遞歸搜索子目錄,忽略大小寫
             
                findstr main.cpp main              在文件中搜索,大小寫敏感
                findstr main.cpp main -i           在文件中搜索,忽略大小寫 

              上面所述的示例中,str不限于特定的文本,可以是帶正則表達(dá)式的匹配模式。而第3種方法,也可以用sed替換grep來(lái)顯示文本行,在此基礎(chǔ)上能作更多的處理,比如格式化顯示、統(tǒng)計(jì)匹配的文本個(gè)數(shù)、搜索策略等,在此就不詳究了。
            posted on 2011-08-20 19:46 春秋十二月 閱讀(2476) 評(píng)論(0)  編輯 收藏 引用 所屬分類: System
            亚洲精品乱码久久久久久蜜桃图片 | 久久精品无码一区二区三区日韩| 久久99毛片免费观看不卡| 久久国产精品一区二区| 久久久久香蕉视频| 亚洲精品白浆高清久久久久久| 国产精品久久久福利| 久久久久久久91精品免费观看 | 香蕉久久夜色精品升级完成| 国产一级持黄大片99久久| 日日狠狠久久偷偷色综合0| 中文字幕热久久久久久久| 秋霞久久国产精品电影院| 国产精品久久久久久久久久影院| 国产一区二区三区久久| 国产亚洲精久久久久久无码77777| 久久青青草原国产精品免费| 77777亚洲午夜久久多喷| 久久人人超碰精品CAOPOREN| 久久超碰97人人做人人爱| 伊人 久久 精品| 久久精品国产亚洲精品| 99国产精品久久久久久久成人热| 欧美日韩精品久久久免费观看| 国产精品岛国久久久久| 狠狠综合久久AV一区二区三区| 久久精品中文字幕一区| 久久国产精品99精品国产| 中文字幕精品久久| 久久九九久精品国产| 99久久无码一区人妻| 国产精品青草久久久久婷婷| 久久婷婷成人综合色综合| 国产69精品久久久久9999APGF| 亚洲另类欧美综合久久图片区| 久久精品中文字幕有码| 久久夜色精品国产亚洲av| 精品久久综合1区2区3区激情| 久久久久四虎国产精品| 国产精品gz久久久| 亚洲国产精品嫩草影院久久|