【Linux】常用命令

文本三剑客

三者的功能都是处理文本,但侧重点各不相同,其中属awk功能最强大,但也最复杂。grep更适合单纯的查找或匹配文本,sed更适合编辑匹配到的文本,awk更适合格式化文本,对文本进行较复杂格式处理。

正则表达式

正则表达式可以使用正则表达式引擎实现,正则表达式引擎是解释正则表达式模式并使用这些模式匹配文本的基础软件。

在Linux中,常用的正则表达式有:

  • POSIX 基本正则表达式(BRE)引擎
  • POSIX 扩展正则表达式(BRE)引擎

基本正则表达式

  • 匹配字符
  . 匹配任意单个字符,不能匹配空行
  [] 匹配指定范围内的任意单个字符
  [^] 取反
  [:alnum:][0-9a-zA-Z]
  [:alpha:][a-zA-Z]
  [:upper:][A-Z]
  [:lower:][a-z]
  [:blank:] 空白字符(空格和制表符)
  [:space:] 水平和垂直的空白字符(比[:blank:]包含的范围广)
  [:cntrl:] 不可打印的控制字符(退格、删除、警铃...)
  [:digit:] 十进制数字 或[0-9]
  [:xdigit:]十六进制数字
  [:graph:] 可打印的非空白字符
  [:print:] 可打印字符
  [:punct:] 标点符号

在这里插入图片描述

  • 配置次数
 -  匹配前面的字符任意次,包括0次,贪婪模式:尽可能长的匹配
 .*  任意长度的任意字符,不包括0次
 \?  匹配其前面的字符0 或 1\+  匹配其前面的字符至少1次
 \{n\}  匹配前面的字符n次
 \{m,n\}  匹配前面的字符至少m 次,至多n次
 \{,n\}  匹配前面的字符至多n次
 \{n,\}  匹配前面的字符至少n次

在这里插入图片描述

  • 位置锚定
 ^  行首锚定,用于模式的最左侧
 $  行尾锚定,用于模式的最右侧
 ^PATTERN$,用于模式匹配整行
 ^$ 空行
 ^[[:space:]].*$  空白行
 \<\b  词首锚定,用于单词模式的左侧
 \>\b  词尾锚定;用于单词模式的右侧
 \<PATTERN\>

在这里插入图片描述

  • 分组与后向引用

① 分组:\(\)将一个或多个字符捆绑在一起,当作一个整体进行处理
分组括号中的模式匹配到的内容会被正则表达式引擎记录于内部的变量中,这些变量的命名方式为: \1, \2, \3, …

② 后向引用
引用前面的分组括号中的模式所匹配字符,而非模式本身
- \1 表示从左侧起第一个左括号以及与之匹配右括号之间的模式所匹配到的字符
- \2 表示从左侧起第2个左括号以及与之匹配右括号之间的模式所匹配到的字符,以此类推
- & 表示前面的分组中所有字符

③ 流程分析如下:
在这里插入图片描述
在这里插入图片描述

扩展正则表达式

  1. 字符匹配:
 .  任意单个字符
 []  指定范围的字符
 [^] 不在指定范围的字符
  1. 次数匹配:
 * :匹配前面字符任意次
 ?  : 0 或1次
 + :1 次或多次
 {m} :匹配m次 次
 {m,n} :至少m ,至多n次
  1. 位置锚定:
 ^ : 行首
 $ : 行尾
 \<, \b : 语首
 \>, \b : 语尾
   分组:()
 后向引用:\1, \2, ...

grep

Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。

  1. grep的工作方式:在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到标准输出,不影响原文件内容。

  2. grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。

  3. egrep = grep -E:扩展的正则表达式 (除了< , > , \b 使用其他正则都可以去掉\)

命令格式

grep [option] pattern file

用于过滤/搜索的特定字符。可使用正则表达式能多种命令配合使用,使用上十分灵活。

  • 命令参数:
 -A<显示行数>:除了显示符合范本样式的那一列之外,并显示该行之后的内容。
 -B<显示行数>:除了显示符合样式的那一行之外,并显示该行之前的内容。
 -C<显示行数>:除了显示符合样式的那一行之外,并显示该行之前后的内容。
 -c:统计匹配的行数
 -e :实现多个选项间的逻辑or 关系
 -E:扩展的正则表达式
 -f FILE:从FILE获取PATTERN匹配
 -F :相当于fgrep
 -i --ignore-case #忽略字符大小写的差别。
 -n:显示匹配的行号
 -o:仅显示匹配到的字符串
 -q: 静默模式,不输出任何信息
 -s:不显示错误信息。
 -v:显示不被pattern 匹配到的行,相当于[^] 反向匹配
 -w :匹配 整个单词
  • 示例
    在这里插入图片描述

sed

sed 是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间(patternspace)”,接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。然后读入下行,执行下一个循环。如果没有使诸如‘D’的特殊命令,那会在两个循环之间清空模式空间,但不会清空保留空间。这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出或-i
功能:主要用来自动编辑一个或多个文件, 简化对文件的反复操作

命令格式

sed [options] '[地址定界] command' file(s)

awk

参考文献:https://www.cnblogs.com/along21/p/10366886.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值