• Android过滤Logcat输出


    logcat和grep配合使用

    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。
  • 相关阅读:
    [经验交流] kubernetes v1.11 更新了高可用方案
    Java泛型和编译优化的一个例子
    Java泛型和编译优化的一个例子
    Java泛型和编译优化的一个例子
    浅析JSONP-解决Ajax跨域访问问题
    java设计原则---开闭原则
    for,foreach,iterator的用法和区别
    List,Set,Map三种接口的区别
    为什么接口中定义的变量必须为常量?
    重写,string创建内存问题
  • 原文地址:https://www.cnblogs.com/adm1989/p/3512748.html
Copyright © 2020-2023  润新知