zoukankan      html  css  js  c++  java
  • linux中grep的用法

     http://www.9usb.net/200902/linux-grep.html

    http://blog.51yip.com/linux/1008.html

    http://blog.csdn.net/svod/article/details/5786656(内容如下)

    找出文件夹下包含 “aaa” 同时不包含 “bbb”的文件,然后把他们重新生成一下。要求只能用一行命令。

    我对Linux 是个白痴,工作了之后才开始接触的,会用的命令只有那几个常用的。这个问题对我来说就有点难度,我只是大概知道查找文件用 grep ,其他的就不知道了。不过没关系,用Google ,查找到 grep 的完整用法:

    1、grep -l ‘boss’ * 显示所有包含boss的文件名。
    2、grep -n ‘boss’ file在匹配行之前加行号。
    3、grep -i ‘boss’ file显示匹配行,boss不区分大小写。
    4、grep -v ‘boss’ file显示所有不匹配行。
    5、grep -q ‘boss’ file找到匹配行,但不显示,但可以检查grep的退出状态。(0为匹配成功)
    6、grep -c ‘boss’ file只显示匹配行数(包括0)。
    7、grep “$boss” file扩展变量boss的值再执行命令。
    8、ps -ef|grep “^*user1″ 搜索user1的命令,即使它前面有零个或多个空格。
    9、ps -e|grep -E ‘grant_server|commsvr|tcpsvr|dainfo’ 查找多个字符串的匹配(grep -E相当于egrep)


    了解了grep的参数之后,问题就解决了一半了,因为可以搜索出符合条件的文件了。不过光有grep 还是不行,因为要把搜索出来的文件名作为参数传给 generate 命令。OK,接下来该管道符出场了。

    即使是像我这样对Linux只是有一点了解的人也经常用到管道符,比如“|”,示例: ls -a | more 。但是对于管道符的具体意义和它做了什么我就不知道了,没关系,Google 一下,找到一些资料:

    利用Linux所提供的管道符“|”将两个命令隔开,管道符左边命令的输出就会作为管道符右边命令的输入。连续使用管道意味着第一个命令的输出会作为第二个命令的输入,第二个命令的输出又会作为第三个命令的输入,依此类推。

    所以查找的时候可以这样写:

    grep -rl “aaa” * | grep -v “bbb”

    这样右边的命令就可以从前面的结果中筛选了。然后还有 generate 命令,因为生成文件的命令格式是这样的:

    generate 文件名

    不过如果直接使用 generate grep -rl “aaa” * | grep -v “bbb” 的话会出错,因为命令会从左向右执行,这条命令就会把grep作为一个文件名来看待。怎么办呢?这个时候就要使用 · (键盘上数字键1 旁边的那个符号,和“~”在一个按键上)来做命令替换了,用 · 把后面的 grep 命令包起来就好了,这样:

    generate ·grep -rl “aaa” * | grep -v “bbb”·

    然后就搞定了。

    http://www.linuxidc.com/Linux/2011-04/34694.htm

  • 相关阅读:
    maven中net.sf.json报错的解决方法(转载)
    [PY3]——环境配置(1)——pyenv | pip | ipython | jupyter(含安装pyenv环境shell脚本)
    [LNMP]——LNMP环境配置
    Tomcat
    Amoeba+Mysql 实现读写分离
    LVS+keepalived DR模式配置高可用负载均衡集群
    [Mysql高可用]——双主互备+keepalived
    Mysql 日志管理
    Mysql基本操作总结
    [Mysql]——通过例子理解事务的4种隔离级别
  • 原文地址:https://www.cnblogs.com/youxin/p/3181058.html
Copyright © 2011-2022 走看看