如何使用带有多个字符分隔符的cut? Unix [英] How to use cut with multiple character delimiter? unix

查看:150
本文介绍了如何使用带有多个字符分隔符的cut? Unix的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我的文件看起来像这样

abc ||| xyz ||| foo bar
hello world ||| spam ham jam ||| blah blah

我想提取特定的列,例如我可以这样做:

I want to extract a specific column, e.g. I could have done:

sed 's/\s|||\s/\\t/g' file | cut -f1

但是还有其他方法吗?

推荐答案


由于 | 是有效的正则表达式,因此需要对其进行转义 \\ | 或放在方括号 [|]

Since | is a valid regex expression, it need to be escaped \\| or put in square brackets [|]

您可以执行以下操作:

awk -F' \\|\\|\\| ' '{print $1}' file

其他一些可行的变体方式

Some other variation that work as well

awk -F' [|][|][|] ' '{print "$1"}' file
awk -F' [|]{3} ' '{print "$1"}' file
awk -F' \\|{3} ' '{print "$1"}' file
awk -F' \\|+ ' '{print "$1"}' file
awk -F' [|]+ ' '{print "$1"}' file




\ 因为分隔符在方括号中不起作用,只能转义,并且有许多逃脱:)

\ as separator does not work well in square brackets, only escaping, and many escape :)



cat file
abc \\\ xyz \\\ foo bar

例如:4 \ 表达式中的每个 \ ,因此总计12个 \

Example: 4 \ for every \ in the expression, so 12 \ totalt.

awk -F' \\\\\\\\\\\\ ' '{print $2}' file
xyz

awk -F' \\\\{3} ' '{print $2}' file
xyz

或者这个,但并不简单

awk -F' [\\\\]{3} ' '{print $2}' file
xyz

awk -F' [\\\\][\\\\][\\\\] ' '{print $2}' file
xyz

这篇关于如何使用带有多个字符分隔符的cut? Unix的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆