正则表达式

 

1、split命令

用于将一个大文件分割成较小的文件,默认每 1000 行分割成一个小文件。有时需要将文件分割成更小的片段,比如为提高可读性、生成日志等。

命令格式

split [OPTION]... [FILE [PREFIX]]

 -l :指定多少行分割成一个小文件

-b,  指定每一子输出文件的大小

示例:

 2、paste命令

  • -d: 制定不同于空格或tab键的域分隔符。比如使用@分隔符,就可以-d@
  • -s: 将每个文件合并成行,而不是按行合并。(即每个文件中的内容占一行。而不是从每个文件取行 合并成新行,具体见下面示例)

示例 :

 

3、 eval命令

使用 eval命令可以置换该变量,执行相应的命令。第一次扫描进行了变量置换,第二次扫描执行了该字符串中所包含的命令cat test和echo命令。

示例:

基础正则表达式常见元字符

(支持的工具:grep、egrep、sed、awk)

\*转义字符,用于取消特殊符号的含义,例:\!、\n、\s等
^匹配字符串开始的位置,例:^ a、^ the、^ #、^ [a-z]
$匹配字符串结束的位置,例:word、^ 匹配空行
.匹配除\n之外的任意的一个字符,有且仅有一个。例:go.d、g…d
*匹配前面子表达式0次或者多次,例:goo*dgo.*d
[list]匹配list列表中的一个字符,例:go[ola]d,[abc]、[a-z]、[a-z0-9]
[^list]匹配任意非list列表中的一个字符,例:[ ^A-Z0-9],[ ^a-z]匹配任意一位非小写字母
\ {n\ }匹配前面的子表达式n次,例:go{2}d'[0-9]{2}'匹配两位数字
\ {n,\ }匹配前面的子表达式不少于n次,例:go{2,}d'[0-9]{2,}'匹配两位及两位以上数字
\ {n,m\ }匹配前面的子表达式n到m次,例:go{2,3}d'[0-9]{2,3}'匹配两位到三位数字

注: egrep、 awk使用{n}、{n,}、{n, m}匹配时 "{ }" 前不用加" \ "

示例1:转义字符\

\ 可以把一些特殊的符号转换成普通的符号字符,还可以把一些普通字符转换成特殊功能。

将特殊的符号转换成普通字符:

\ &单个&代表后台运行
\ l单个 l 代表“或”
\ !单个 ! 代表取反
\ =单个=代表复制或者字符判断
\ $单个$代表引用变量

 将普通字符转换成特殊功能:

\n转换后是换行符
\t转换后是制表符
\r转换后是回车符
\w匹配包括下划线的任何单词字符
\W(大写)匹配任何非单词字符。等价于"[^A-Za-z0-9_]"
\d匹配一个数字字符
\D匹配一个非数字字符。等价于[^0-9]
\s空白符
\S非空白符

示例一、 ^匹配开头,$匹配结尾

示例二、. 和 * 

.号:匹配除\n之外的任意的一个字符,有且仅有一个。

*号:匹配前面子表达式0次或者多次。

示例三、[list]

[list] 匹配括号内的任意一个字符,只能匹配单个字符。

[ ^list] ,^在括号内表示取反。即匹配括号内字符以外的任意一个字符,只能匹配单个字符。

扩展正则表达式元字符

(支持的工具:egrep、 awk、 grep-E、 sed -r)

+匹配前面子表达式1次及以上,例: go+d,将匹配至少一个o,如god、good、 goood等
?匹配前面子表达式0次或者1次,例: go?d,将匹配gd或god
( )将括号中的字符串作为一个整体,例1: g(0o)+d,将匹配oo整体1次以上,如good、gooood等
l以"或"的方式匹配字符串

 +:匹配前面的子表达式1次及以上(至少1次)

 ?:匹配前面子表达式0次或者1次

 ( ):将括号中的字符串作为一个整体

示例、 区号025开头,号码与区号间可以是空格、-、没有,号码必须是5或者8开头的八位数

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值