Android過濾Logcat輸出

logcat和grep配合使用android

1.打印特定tag的log,如打印Tag爲Adm的Log
       adb logcat | grep Adm
        adb logcat | grep -i adm   #忽略大小寫
       adb logcat | grep --color=auto -i  adm    #設置匹配字符串顏色
       上面的 例子會匹配一行中任意位置的 Adm,若是想匹配相似於I/CacheService(  665): Preparing DiskCache for all thumbnails. 能夠將表達式寫爲
        adb logcat | grep "^./Adm"  #匹配全部級別
        adb logcat | grep "^E/Adm"   # 僅顯示 Error 級別 tag 爲 Adm 的輸出
 
2.過濾不須要的輸出,黑名單
        adb logcat | grep -v Adm   #使用 grep,用法也跟上面的同樣,加一個 -v 便可
 
3.打印出同一個應用中的Log

       實現思路:同一個應用在Linux下面擁有同一個PID,因此先根據包名找到pid號,而後匹配pid正則表達式

       ps | grep "com.android.settings"      # grep 後面接應用包名
       經過上面的指令能夠獲得應用程序的pid號,輸出結果的第二列,能夠經過ps指令看出每一列分別表示什麼
       adb logcat | grep --color=auto pid  #
 
附grep基本用法
用法: grep [選項]... PATTERN [FILE]...
在每一個 FILE 或是標準輸入中查找 PATTERN。
默認的 PATTERN 是一個基本正則表達式(縮寫爲 BRE)。
例如: grep -i 'hello world' menu.h main.c
 
正則表達式選擇與解釋:
  -E, --extended-regexp     PATTERN 是一個可擴展的正則表達式(縮寫爲 ERE)
  -F, --fixed-strings       PATTERN 是一組由斷行符分隔的定長字符串。
  -G, --basic-regexp        PATTERN 是一個基本正則表達式(縮寫爲 BRE)
  -P, --perl-regexp         PATTERN 是一個 Perl 正則表達式
  -e, --regexp=PATTERN      用 PATTERN 來進行匹配操做
  -f, --file=FILE           從 FILE 中取得 PATTERN
  -i, --ignore-case         忽略大小寫
  -w, --word-regexp         強制 PATTERN 僅徹底匹配字詞
  -x, --line-regexp         強制 PATTERN 僅徹底匹配一行
  -z, --null-data           一個 0 字節的數據行,但不是空行
 
雜項:
  -s, --no-messages         不顯示錯誤信息
  -v, --invert-match        選中不匹配的行
  -V, --version             顯示版本信息並退出
      --help                顯示此幫助並退出
      --mmap                忽略向後兼容性
 
輸出控制:
  -m, --max-count=NUM       NUM 次匹配後中止
  -b, --byte-offset         輸出的同時打印字節偏移
  -n, --line-number         輸出的同時打印行號
      --line-buffered       每行輸出清空
  -H, --with-filename       爲每一匹配項打印文件名
  -h, --no-filename         輸出時不顯示文件名前綴
      --label=LABEL         將LABEL 做爲標準輸入文件名前綴
  -o, --only-matching       show only the part of a line matching PATTERN
  -q, --quiet, --silent     suppress all normal output
      --binary-files=TYPE   assume that binary files are TYPE;
                            TYPE is 'binary', 'text', or 'without-match'
  -a, --text                equivalent to --binary-files=text
  -I                        equivalent to --binary-files=without-match
  -d, --directories=ACTION  how to handle directories;
                            ACTION is 'read', 'recurse', or 'skip'
  -D, --devices=ACTION      how to handle devices, FIFOs and sockets;
                            ACTION is 'read' or 'skip'
  -r, --recursive           like --directories=recurse
  -R, --dereference-recursive  likewise, but follow all symlinks
      --include=FILE_PATTERN  只查找匹配FILE_PATTERN 的文件
      --exclude=FILE_PATTERN  跳過匹配FILE_PATTERN 的文件和目錄
      --exclude-from=FILE   跳過全部除FILE 之外的文件
      --exclude-dir=PATTERN  跳過全部匹配PATTERN 的目錄。
  -L, --files-without-match  只打印不匹配FILEs 的文件名
  -l, --files-with-matches  只打印匹配FILES 的文件名
  -c, --count               只打印每一個FILE 中的匹配行數目
  -T, --initial-tab         行首tabs 分隔(若有必要)
  -Z, --null                在FILE 文件最後打印空字符
 
文件控制:
  -B, --before-context=NUM  打印以文本起始的NUM 行
  -A, --after-context=NUM   打印以文本結尾的NUM 行
  -C, --context=NUM         打印輸出文本NUM 行
  -NUM                      same as --context=NUM
      --color[=WHEN],
      --colour[=WHEN]       use markers to highlight the matching strings;
                            WHEN is 'always', 'never', or 'auto'
  -U, --binary              do not strip CR characters at EOL (MSDOS/Windows)
  -u, --unix-byte-offsets   report offsets as if CRs were not there
                            (MSDOS/Windows)
 
‘egrep’即‘grep -E’。‘fgrep’即‘grep -F’。
直接使用‘egrep’或是‘fgrep’均已不可行了。
若FILE 爲 -,將讀取標準輸入。不帶FILE,讀取當前目錄,除非命令行中指定了-r 選項。
若是少於兩個FILE 參數,就要默認使用-h 參數。
若是有任意行被匹配,那退出狀態爲 0,不然爲 1;
若是有錯誤產生,且未指定 -q 參數,那退出狀態爲 2。
相關文章
相關標籤/搜索