博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux基本配置和管理 3 ---- Linux命令行文本处理工具
阅读量:6123 次
发布时间:2019-06-21

本文共 1496 字,大约阅读时间需要 4 分钟。

 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就比较方便

      

 

你可能感兴趣的文章
android防止内存溢出浅析
查看>>
4.3.3版本之引擎bug
查看>>
SQL Server表分区详解
查看>>
使用FMDB最新v2.3版本教程
查看>>
SSIS从理论到实战,再到应用(3)----SSIS包的变量,约束,常用容器
查看>>
STM32启动过程--启动文件--分析
查看>>
垂死挣扎还是涅槃重生 -- Delphi XE5 公布会归来感想
查看>>
淘宝的几个架构图
查看>>
Android扩展 - 拍照篇(Camera)
查看>>
JAVA数组的定义及用法
查看>>
充分利用HTML标签元素 – 简单的xtyle前端框架
查看>>
设计模式(十一):FACADE外观模式 -- 结构型模式
查看>>
iOS xcodebuile 自动编译打包ipa
查看>>
程序员眼中的 SQL Server-执行计划教会我如何创建索引?
查看>>
【BZOJ】1624: [Usaco2008 Open] Clear And Present Danger 寻宝之路(floyd)
查看>>
cmake总结
查看>>
数据加密插件
查看>>
linux后台运行程序
查看>>
win7 vs2012/2013 编译boost 1.55
查看>>
IIS7如何显示详细错误信息
查看>>