• <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  評論-223  文章-30  trackbacks-0
            方法1:使用find和xargs命令
                 find dir | xargs grep str,dir是指某個目錄
                 find file | xargs grep str,file是指某個文件
               注意:這種方法,會遞歸搜索子目錄

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

            方法3:綜合以上兩種,寫一個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
              這樣一來,不管$1參數是目錄還是文件,都能處理,使用示例如下:
                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不限于特定的文本,可以是帶正則表達式的匹配模式。而第3種方法,也可以用sed替換grep來顯示文本行,在此基礎上能作更多的處理,比如格式化顯示、統計匹配的文本個數、搜索策略等,在此就不詳究了。
            posted on 2011-08-20 19:46 春秋十二月 閱讀(2476) 評論(0)  編輯 收藏 引用 所屬分類: System
            久久综合亚洲鲁鲁五月天| 一本久久综合亚洲鲁鲁五月天| 老司机午夜网站国内精品久久久久久久久 | 精品一久久香蕉国产线看播放 | 曰曰摸天天摸人人看久久久| 精品久久久久国产免费| 中文字幕热久久久久久久| 亚洲成色999久久网站| 午夜人妻久久久久久久久| 伊人久久大香线蕉无码麻豆| 香蕉久久一区二区不卡无毒影院 | 精品国产综合区久久久久久| 久久久久久久综合日本| 久久亚洲精品成人无码网站| 久久精品国产精品亚洲| 69国产成人综合久久精品| 思思久久99热免费精品6| 国产一区二区久久久| 亚洲国产成人久久综合野外 | 99国产欧美精品久久久蜜芽| 精品人妻久久久久久888| 中文字幕乱码人妻无码久久| 久久人妻无码中文字幕| 国产精品九九九久久九九| 久久se这里只有精品| 亚洲精品高清久久| 伊人色综合九久久天天蜜桃| 漂亮人妻被黑人久久精品| 日韩人妻无码精品久久免费一 | 国产精品99久久久久久人| 国产99久久精品一区二区| 欧美激情精品久久久久| 久久亚洲国产最新网站| 久久综合久久综合九色| 欧美日韩精品久久免费| 久久精品国产色蜜蜜麻豆 | 91精品国产色综合久久| 精品国产日韩久久亚洲| 久久精品一区二区影院| 狠狠久久亚洲欧美专区| 无码8090精品久久一区|