图片拍摄自上海黄陂南路
场景
假设我们现在有这样一段文本
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:" '' | awk -F'\\|\\|' ''
如果简单还好,但是一旦字符串复杂,这种方式就很容易出错
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:|[\\|][\\|]' ''
其中,||是个字符串,又属于特殊字符,所以在使用的时候,需要加上\进行转义
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:|\\|\\|' ''
结果都是一样的
注:|是特殊字符,所以需要用\\进行转义
BTW:上面的字符串操作,同样可以用:和| 作为分隔符
领取专属 10元无门槛券
私享最新 技术干货