• <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>
            隨筆-162  評論-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參數(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不限于特定的文本,可以是帶正則表達式的匹配模式。而第3種方法,也可以用sed替換grep來顯示文本行,在此基礎上能作更多的處理,比如格式化顯示、統(tǒng)計匹配的文本個數(shù)、搜索策略等,在此就不詳究了。
            posted on 2011-08-20 19:46 春秋十二月 閱讀(2488) 評論(0)  編輯 收藏 引用 所屬分類: System
            久久天天日天天操综合伊人av| 亚洲一本综合久久| 欧美一级久久久久久久大片| 久久免费精品视频| 国产精品一久久香蕉产线看| 久久99国产精品尤物| 精品熟女少妇a∨免费久久| 久久国产精品无码一区二区三区 | 国产麻豆精品久久一二三| 日韩精品久久久久久久电影蜜臀| 亚洲精品高清国产一线久久| 成人久久免费网站| 久久婷婷五月综合国产尤物app| 三上悠亚久久精品| 国产精品久久久久久吹潮| 青青国产成人久久91网| 国产激情久久久久影院老熟女| 国产精品狼人久久久久影院| 久久久久亚洲爆乳少妇无| 伊人色综合久久天天人守人婷| 亚洲精品乱码久久久久久久久久久久| 人妻丰满AV无码久久不卡| 亚洲天堂久久精品| 欧美激情一区二区久久久| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 久久精品国产亚洲综合色| 久久se这里只有精品| 久久久国产99久久国产一| 蜜臀久久99精品久久久久久小说| 国产欧美久久一区二区| 理论片午午伦夜理片久久 | 天天综合久久一二三区| 亚洲愉拍99热成人精品热久久| 欧美亚洲国产精品久久蜜芽| 久久99热这里只频精品6| 久久99中文字幕久久| 一本久久a久久精品综合香蕉| 成人免费网站久久久| 久久婷婷人人澡人人爽人人爱| 久久国产免费观看精品| 一本久道久久综合狠狠爱|