一、常用简单工具

  cat [OPTION]... [FILE]... 

  •   -E:显示行的结束符$
  •   -n:对显示出的每一行进行编号。
  •   -A:显示所有控制符
  •   -s:压缩连续空行为一行
  more:分页查看文件 
   -d: 显示翻页及退出提示 
  less:一页一页地查看文件或STDIN输出
  查看时有用的命令包括:
  /文本 搜索 文本
  n/N 跳到下一个 或 上一个匹配
  less 命令是man命令使用的分页器
  文本切割cut [OPTION]... [FILE]... 
  •   -f:取第几个字段
  •   -c:按字符切割
  •   -d:指定切割符,默认为tab
  wc文本数据统计
  •   -l:只计算行数
  •   -w:world,只计算单词的总数
  •   -c:只计算字节总数
  •   -m:只是计算字符总数
  •   -L:显示文件中最长行的长度
  sort,文本排序
  •   -r:倒序输出
  •   -R:随机排序
  •   -n:执行按照数字大小整理
  •   -f:选项忽略(fold)字符串中的字符大小写
  •   -u:删除输出中的重复行
  •   -t c使用c作为字段的界定符
  •   -k X选项按照使用c字段分割的X列来整理能使用多次
  uniq统计工具
  •   -c:显示每行重复出现的次数
  •   -d:仅显示重复的行
  •   -u:显示不重复的行
  •   常和sort 命令一起配合使用: sort userlist.txt | uniq -c
  grep文本过滤
  作用:文本搜索工具,根据用户指定的“模式”对目标文本逐行进行匹配检查;打印匹配到的行
  grep [OPTIONS] PATTERN [FILE...] 
  •   -m #:匹配到#次后停止
  •   -v:显示不被pattern匹配到的行
  •   -i:忽略大小写
  •   -c:统计匹配到的行数
  •   -o:仅显示匹配到的行
  •   -q:静默模式,不输出任何信息
  •   -A #:after后#hang
  •   -B #:before,前#行
  •   -C #:context,前后各#行
  •   -e:现实多个选项间的或关系grep –e ‘cat ’ -e ‘dog’ file
  •   -w: 匹配整个单词
  •   -E :使用ERE
  •   -F :相当于fgrep,不支持正则表达式
  •   -f :file 根据模式文件处理

二、正则表达式

  REGEXP: Regular Expressions,由一类特殊字符及文本字符所编写的模式,其中有些字符(元字符)不表示字符字面意义,而表示控制或通配的功能
  程序支持:grep,sed,awk,vim, less,nginx,varnish等 
  分两类:基本正则表达式:BRE,扩展正则表达式:ERE 
  基本正则表达式元字符 
  •   . 匹配任意单个字符
  •   [] 匹配指定特定范围内任意单个字符,式列:[li]  [wang] [0-9]
  •   [^] 匹配指定范围外的任意单个字符
  •  [:alnum:]字符和字母
  •   [:alpha:]代表任何英文大小写字符,a-z,A-Z
  •   [:lower:]小写字母[:upper:] 大写字母
  •   [:blank:] 空白字符,空格,制表符等
  •   [:space:]水平和垂直的空白字符(比[:blank:]包含的范围广)
  •   [:cntrl:] 不可打印的控制字符(退格、删除、警铃...
  •   [:digit:] 十进制数字 [:xdigit:]十六进制数字
  •   [:graph:]可打印的非空白字符
  •   [:print:]可打印字符
  •   [:punct:]标点符号
  •   * 匹配前面的字符任意次,包括0次贪婪模式:尽可能长的匹配
  •   .* 任意长度的任意字符
  •   \? 匹配其前面的字符0或1次
  •   \+ 匹配其前面的字符至少1次
  •   \{n\} 匹配前面的字符n次
  •   \{m,n\} 匹配前面的字符至少m次,至多n次
  •   \{,n\} 匹配前面的字符至多n次
  •   \{n,\} 匹配前面的字符至少n次

位置锚定:定位出现的位置 

  •   ^ 行首锚定,用于模式的最左侧
  •    $ 行尾锚定,用于模式的最右侧   
  •   ^PATTERN$ 用于模式匹配整行  
  •   ^$ 空行  
  •    ^[[:space:]]*$ 空白行  
  •    \< 或 \b 词首锚定,用于单词模式的左侧  
  •    \> 或 \b 词尾锚定,用于单词模式的右侧   
  •   \<pattern\> 匹配整个单词
分组和引用
  分组:\(\) 将一个或多个字符捆绑在一起,当作一个整体处理,如:\(root\)\+
  分组括号中的模式匹配到的内容会被正则表达式引擎记录于内部的变量中,这些变量的命名方式为: \1, \2, \3, ...
  \1 表示从左侧起第一个左括号以及与之匹配右括号之间的模式所匹配到的字符
  示例: \(string1\(string2\)\)
  \1 :string1\(string2\)
  \2 :string2
  后向引用:引用前面的分组括号中的模式所匹配字符,而非模式本身
  或者:\|
  示例:a\|b a或b
  C\|cat C或cat
  \(C\|c\)at Cat或cat

linux文本处理工具篇的更多相关文章

  1. Linux文本处理工具

    Linux文本处理工具 Linux中熟练的使用文本处理工具非常的重要, 因为Linux在设计的时候是采用一切皆文件的哲学的, 甚至连计算机中的配置也都使用伪文件系统来表示, 要查询里面的内容就是对文件 ...

  2. Linux文本编译工具VIM详解

    Linux文本编译工具VIM详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.VIM概述 1>.vim简介 >.vi: 全称Visual editor,即文本编辑 ...

  3. Linux文本查看工具

    文本查看工具 cat 特点: 不能用来看二进制文件 选项: -A: 显示不可见字符 cat支持标准输入: cat > aa.txt ---键盘作为标准输入,输出的结果重定向文件中去了 cat & ...

  4. Linux 文本处理工具grep,sed,awk

    grep.sed和awk都是文本处理工具,虽然都是文本处理工具单却都有各自的优缺点,一种文本处理命令是不能被另一个完全替换的,否则也不会出现三个文本处理命令了.只不过,相比较而言,sed和awk功能更 ...

  5. linux 文本分析工具---awk命令(7/1)

    awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各 ...

  6. Linux文本处理工具——Sed

    sed:数据流编辑器: awk:报告文本的生成器 sed 基本用法:(Stream EDitor) Stream 流 EDitor 编辑器 行编辑器 全屏编辑器:vi/vimsed:内存空间(模式空间 ...

  7. linux文本处理工具及正则表达式

    cat命令:查看文本内容 cat [选项]... [文件]... -E    显示行结束符 -n    显示文本内容时显示行号 -A    显示所以控制符 -b    非空行编号 -s     压缩连 ...

  8. linux文本处理工具-1

    文件内容: cat ,more,less 文件截取:head,tail 按列抽取:cut 排序和统计:sort,wc ----------------------------------------- ...

  9. Linux 文本处理工具(grep sed awk )

    ^test: 以test开头; test$: 以test结尾: ^$: 表示空行,不是空格: . :代表且只代表任意一个字符(其他功能:当前目录,加载文件): \ : 代表转义字符,表示特殊字符: * ...

随机推荐

  1. Centos7下源码编译安装与配置redis5.0

    1.下载redis5.0源码包 wget http://download.redis.io/releases/redis-5.0.5.tar.gz 2.检查是否安装过之前的历史版本 rpm -qa|g ...

  2. Oracle Linux下使用sqlplus的edit命令

    1.使当前会话生效 define_editor=vi SQL> select * from dual; D - X SQL> edit Wrote file afiedt.buf 21 1 ...

  3. 容斥原理+补集转化+MinMax容斥

    容斥原理的思想大家都应该挺熟悉的,然后补集转化其实就是容斥原理的一种应用. 一篇讲容斥的博文https://www.cnblogs.com/gzy-cjoier/p/9686787.html 当我们遇 ...

  4. ivew Upload 上传时附带的额外参数

    <Upload action="/api/device/importData" :data="uploadData" :before-upload=&qu ...

  5. java--ArrayList,LinkedList应用比较

    import java.util.ArrayList; import java.util.LinkedList; import java.util.List; public class ListDem ...

  6. 【leetcode】995. Minimum Number of K Consecutive Bit Flips

    题目如下: In an array A containing only 0s and 1s, a K-bit flip consists of choosing a (contiguous) suba ...

  7. Delphi 版本信息获取函数 GetFileVersionInfo、GetFileVersionInfoSize、VerFindFile、VerInstallFile和VerQueryValue

    一.版本信息获取函数简介和作用 获取文件版本信息的作用: 1. 避免在新版本的组件上安装旧版本的相同组件: 2. 在多语言系统环境中,操作系统根据文件版本信息里提供的语言信息在启动程序时决定使用的正确 ...

  8. 【多线程】ConcurrentLinkedQueue 的实现原理

    1. 引言 在并发编程中我们有时候需要使用线程安全的队列.如果我们要实现一个线程安全的队列有两种实现方式:一种是使用阻塞算法,另一种是使用非阻塞算法.使用阻塞算法的队列可以用一个锁(入队和出队用同一把 ...

  9. Struts2 简单的增删改查

    1:主页面 <a href="emp-list">emp-list</a> <br> 然后到struts.xml文件中找到对应的emp-list ...

  10. CF1061E Politics E. Politics 解题报告

    CF1061E Politics E. Politics 考虑利用树的性质,因为是子树问题,所以放到dfs序上. 只考虑一个树,问题是每个区间选恰好\(k\)个.因为区间其实是子树,所以区间要么包含, ...