Linux基本配置和管理 3 ---- Linux命令行文本处理工具

  1. 云栖社区>
  2. 博客>
  3. 正文

Linux基本配置和管理 3 ---- Linux命令行文本处理工具

陈国林 2013-09-03 00:25:43 浏览916
展开阅读全文


 1 文件浏览(简单回顾)

     1 cat 查看文件的内容

     2 more 以翻页的形式查看,但是只能向下翻页

     3 less 以翻页的形式查看,但是能够支持向上和向下翻页

     4 head 默认是查看前10行,但是我们指定查看的行数

     5 tail 默认是查看后10行,但是我们可以指定查看的行数


 2 基于关键字的搜索

     假设我在家目录下创建了一个tmp.cpp

      

     1 命令grep是基于关键字进行搜索

     2 单个关键字搜索:  grep 关键字 文件名

        比如我在tmp.cpp 里面搜索Linux

        

     3 多关键字搜索: grep -E "关键字|关键字..." 文件名

        比如我在tmp.cpp里面同时搜索哦含有Linux 和test

        

     4 grep的其它参数

        1 -i 是忽略大小写

           

        2 -n 是显示结果所在的行

        3 -v 是输出不带关键字的行(等于取反)

        4 -Ax是输出的时候包含结果所在行之后x行

        5 -Bx是输出的时候包含结果所在行之前x行

 

 3 基于列的处理

    1 cut命令是用于基于列的文本处理

    2 cut -dc -fx 文件名 

       c是要分割的字符(默认是TAB),x是显示第几列

       比如我以":"作为分割符 查看/etc/passwad的第1列

              

   2 我们也可以利用管道来进行cut

      比如我先利用grep命令在/etc/passwad中搜索出含有chen关键字的文本结果,然后利用管道去cut出用:作为分割符并且显示第六列

      

      

  

 4 文本统计

    1 wc命令用来统计文本的信息,默认输出几行,几个单词,几个字节,文件名 

       我们还是利用上面的tmp.cpp

       

    2 wc还有一些参数

       -l 只统计行数

       -w 只统计单词

       -c 只统计字节数

       -m 只统计字符数

       


 5 文本排序

    1 命令sort是用来对文本进行排序 sort 文本名

       

   2 sort的常用的参数

       -r 进行倒序排序

       -n 基于数字进行排序

       -r 忽略大小写

       -u 删除重复行

       -tc 使用c作为分割符分割为列进行排序

       -kx 当基于分割符分割为列进行排序时,指定x列来排序 

   3 删除重复行

      sort -u 文件名

      uniq 文件名 用来删除相邻的重复行

 

 6 文本的比较

    1 命令diff用来比较两个文本文件

       diff 文件1 文件2

       比如我们比较家目录下的tmp.cpp 和 tmp2.cpp

                   

        

   2 diff的一些参数

      -i 忽略大小写

      -b 忽略空格的数量

      -u 统一的显示比较的信息,用以生成patch文件,一般可以用来作为补丁,实际上就是把比较信息重定向到patch文件

       

 

 7 文本处理

    1 删除某个关键字

       tr -d 关键字 < 文件名

       

    2 转换大小写

        tr 'a-z' 'A-Z' < 文件名

                        


 7 文本的搜索替换

    命令sed用来实现文本的替换功能,其内部实现的是一个正则表达式

    1 sed 's/linux/unix/g' 文件名

       那么这个命令就是把文本里面的linux替换为unix,g的意思是如果一行有多个linux则全部替换

        

    2 sed '1,50s/linux/unix/g' 文件名

       那么这个命令就是把1~50行里面的linux替换为unix,g的意思是如果一行有多个linux则全部替换

    3 sed -e 's/linux/unix/g' -e 's/haha/fuck/g' 文件名

       那么这个命令就是实现多个同时替换,把所有linux替换为unix,haha替换为fuck

       

    4 sed -f sededit 文件名

       这个命令就是说如果我们很厂用到某个命令,那么我们把这个命令写道sededit文本里面,那么每次调用-f sededit就比较方便


      

网友评论

登录后评论
0/500
评论
陈国林
+ 关注