AWK使用多个分隔符

losetowin 发布于:2019-2-13 22:57 分类:linux  有 903 人浏览,获得评论 0 条 标签: awk 

本文地址:http://www.dutycode.com/awk_duo_fengefu_zifuchuan.html
除非注明,文章均为 www.dutycode.com 原创,欢迎转载!转载请注明本文地址,谢谢。

场景

假设我们现在有这样一段文本

log||click:1,2,3;4,5,6;7,8,9||from=dutycode.com 

如果我们要拿到中间的1,2,3;4,5,6;7,8,9应该怎么做?

解决方案

1.常规方案

借用管道,使用两次awk操作,最终拿到中间值。

echo "log||click:1,2,3;4,5,6;7,8,9||from=dutycode.com" | awk -F"click:" '{print $2}' | awk -F'\\|\\|' '{print $1}' 

如果简单还好,但是一旦字符串复杂,这种方式就很容易出错

2.使用awk的多分隔符操作

分析字符串,要拿到1,2,3;4,5,6;7,8,9,只要将:||作为分隔符即可。

echo "log||click:1,2,3;4,5,6;7,8,9||from=dutycode.com" | awk -F'click:|[\\|][\\|]' '{print $3}' 

其中,||是个字符串,又属于特殊字符,所以在使用的时候,需要加上\进行转义

awk -F"[ab]" '{}' 这种形式指定的分隔符是或的关系,即a或b作为分隔符;
awk -F"[a][b]" '{}' 这种形式指定的分隔符是合并的关系,即以“ab”作为一个字符为分隔符。
所以在上面的命令中,||的表达方式为 [\\|][\\|]

awk -F'a|b' '{}' 这种指定的分隔符,表示a或者b作为分隔符

上面的例子中,我们使用了click:作为分隔符。所以在使用中,我们用了click:|[\\|][\\|]来表示分隔符为click:或者||

3.多个字符串作为分隔符怎么办?

还是上面的例子,我们用click:||作为分隔符,如果分隔符比较多的时候,使用[][]的方式来连接字符串表示合并关系就很费劲了,比如上面,我们为了表示||,使用了[\\|][\\|]

其实可以不用,完全可以使用awk -F'abc|cde' '{}'的方式,表示用abc和cde来作为分隔符。

所以,上面的例子可以改写成

echo "log||click:1,2,3;4,5,6;7,8,9||from=dutycode.com" | awk -F'click:|\\|\\|' '{print $3}' 

结果都是一样的

注: | 是特殊字符,所以需要用\\进行转义

BTW:上面的字符串操作,同样可以用:和| 作为分隔符


版权所有:《攀爬蜗牛》 => 《AWK使用多个分隔符
本文地址:https://www.dutycode.com/awk_duo_fengefu_zifuchuan.html
除非注明,文章均为 《攀爬蜗牛》 原创,欢迎转载!转载请注明本文地址,谢谢。

上一篇:Mysql锁-全局锁
下一篇:TProfiler介绍