一、常用简单工具

  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. mysql修改root密码和设置权限 转摘:http://www.cnblogs.com/wangs/p/3346767.html

    整理了以下四种在MySQL中修改root密码的方法,可能对大家有所帮助! 方法1: 用SET PASSWORD命令 mysql -u root mysql> SET PASSWORD FOR ' ...

  2. 企业微信上传 带中文名称的 临时素材资源 报错 44001:empty media data

    错误原因:urllib3的老版本bug,卸载掉 requests,urllib3,从新安装最新版的requests(此包内部依赖urllib3): 我从新安装的是 requests==2.22.0 及 ...

  3. springboot基于注解动态配置多数据源以及多数据源的事务统一

    参考文档:https://www.cnblogs.com/zhangboyu/p/7622412.html https://blog.csdn.net/qq_34322777/article/deta ...

  4. python-django_rest_framework中的request/Response

    rest_framework中的request是被rest_framework再次封装过的,并在原request上添加了许多别的属性: (原Django中的request可用request._requ ...

  5. ECUST_Algorithm_2019_4

    简要题意及解析 1001 第三次作业原题,略. 1002 把一个数转换为二进制. 不断除以\(2\)取余就好了.写递归代码会非常短. 时间复杂度\(O(Tlogn)\) \(T\)是数据组数,\(n\ ...

  6. Pythonf反射

    Python中,反射有4个方法.分别是:hasattr().getattr().setattr()和delattr(). hasattr() 定义 hasattr()函数用于判断对象是否包含对应的属性 ...

  7. Scrapy爬虫框架的使用

    #_author:来童星#date:2019/12/24# Scrapy爬虫框架的使用#1.安装Twisted模块 https://www.lfd.uci.edu/~gohlke/pythonlibs ...

  8. djangorestframework-jwt 分页器 三种

    数据准备 # models class Teacher(models.Model): name = models.CharField(max_length=32) salary = models.De ...

  9. Python--同步锁(互斥锁)、死锁(状态)、递归锁、信号量、Event对象

    同步锁/互斥锁 (Lock) import time import threading def sub(): global num #在每个线程中都获取这个全局变量 #num-=1 temp=num ...

  10. UNP学习第七章

    一.套接口选项 函数getsockopt和setsockopt 函数fcntl 函数ioctl 二.getsockopt和setsockopt函数 #include <sys/socket.h& ...