• <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>
            隨筆-161  評論-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 春秋十二月 閱讀(2482) 評論(0)  編輯 收藏 引用 所屬分類: System
            久久久久亚洲AV无码网站| 99久久精品日本一区二区免费 | 久久久久人妻一区二区三区vr| 久久成人小视频| 99久久做夜夜爱天天做精品| 香蕉久久影院| 亚洲日韩中文无码久久| 99国产精品久久| 久久国产成人午夜AV影院| 亚洲另类欧美综合久久图片区| 久久精品国产精品亚洲精品 | AV色综合久久天堂AV色综合在| 国产精品18久久久久久vr| 久久久久国产日韩精品网站| 无码人妻久久一区二区三区蜜桃| 久久99国产综合精品女同| 国产伊人久久| 国产精品无码久久综合| 亚洲国产综合久久天堂| 国内精品久久久久久99蜜桃 | 久久电影网一区| 国产精品乱码久久久久久软件 | 精品国产91久久久久久久 | 一本一本久久aa综合精品| 93精91精品国产综合久久香蕉| 久久久亚洲裙底偷窥综合| 久久99久久成人免费播放| 国产精品久久精品| 中文字幕无码精品亚洲资源网久久| 欧美亚洲另类久久综合| 精品久久久无码人妻中文字幕豆芽 | 久久综合九色综合久99| 99久久久精品| 国产亚洲精品美女久久久| 久久九九兔免费精品6| 久久亚洲色一区二区三区| 91精品久久久久久无码| 久久99精品久久只有精品| 久久精品aⅴ无码中文字字幕不卡| 国色天香久久久久久久小说| 久久人人添人人爽添人人片牛牛|