生物信息学与算法

sed中的正则匹配

2020-06-28  本文已影响0人  生信编程日常

sed很早就支持正则表达式了,这在文件处理中非常有用,以下列出一些常见用法(GNU SED版本)。

1. 行首/行尾

行首用^表示,行尾用$表示。例如有如下test.txt文件:


如果我们想把其中第一列的Potri.去掉,那么可以:

sed 's/^Potri.//g' test.txt 

假如想在最后数字的后面加一列"yes":

sed 's/$/\tyes/g' test.txt
2. 匹配字符

(来自https://wiki.jikexueyuan.com/project/unix/regular-expressions.html)

比较常用的有:

字符 含义
. 匹配除换行符以外的任意字符
\w 匹配字母或数字或下划线
\s 任意的空白符(包括空格制表符换页符)
[0-9] 任意0到9中数字
[a-zA-Z] 26个英文字母中的一个,不区分大小写
3. 匹配在列表中的任意字符

用[]代表这样的列表,比如:

echo -e "Cat\nBat\nHat" | sed -n '/[CH]at/ p'

结果输出:
Cat
Hat
[]代表从其中选择一个。

4. 不在列表中的任意字符
echo -e "Cat\nBat\nHat" | sed -n '/[^CH]at/ p'

仅输出Bat。

5. 匹配出现某种次数(+; * ; ?; {n}; {n,}; {m,n})

出现不止一次(>= 1): \+
出现0或1次:\?
出现n次:{n}
出现>=n次:{n,}
出现m到n次:{m, n}

注意前后括号{}都需要转义。

6. 或者

或者 | 常与 () 一起使用,注意两者都需要反斜杠\转义。

echo -e "Cat\nBat\nHat" | gsed -n '/\(C\|B\|H\)at/p'
7. 特殊字符转义

一些特殊字符比如换行符\n或者回车\r等,匹配的时候在前面再加一个反斜杠转义,如\\r。

8. 例子

匹配上海市电话号码:

# eg. 021-52060888
echo 021-52060888 | sed -n '/^012-[0-9]\{8\}/p'

匹配ip地址:

echo '127.255.255.254' | sed -n '/[0-9]\+.[0-9]\+.[0-9]\+.[0-9]\+/p'

值得注意的是,在sed中不支持\d匹配数字,此处须用[0-9]。

欢迎关注!


上一篇 下一篇

猜你喜欢

热点阅读