假设我有字符串1:2:3:4:5,我想要得到它的最后一个字段(在本例中是5)。我如何使用Bash做到这一点?我试过cut,但我不知道如何用-f指定最后一个字段。
当前回答
对不起,我不能评论,但在这里; 来自@mateusz-piotrowski @user3133260的答案,
回声“e b: c: d::::::“| tr ':' ' ' | xargs | tr ' ' ' \ n ' |尾1
首先,tr ':' ' ' ->将':'替换为空格
然后,用xargs修整
之后,tr ' ' '\n' ->将保留的空格替换为换行符
最后,tail -1 ->得到最后一个字符串
其他回答
对于那些熟悉Python的人来说,https://github.com/Russell91/pythonpy是解决这个问题的一个不错的选择。
$ echo "a:b:c:d:e" | py -x 'x.split(":")[-1]'
将stdin的每一行都视为x。
使用该工具,可以很容易地编写应用于输入的python代码。
编辑(2020年12月): Pythonpy不再在线。 这里有一个替代方案:
$ echo "a:b:c:d:e" | python -c 'import sys; sys.stdout.write(sys.stdin.read().split(":")[-1])'
它包含更多的样板代码(即sys.stdout.read/write),但只需要来自python的STD库。
你可以使用字符串操作符:
$ foo=1:2:3:4:5
$ echo ${foo##*:}
5
这将从前面到':'贪婪地修剪所有内容。
${foo <-- from variable foo
## <-- greedy front trim
* <-- matches anything
: <-- until the last ':'
}
如果你想使用cut,你可以尝试这样做:
echo "1:2:3:4:5" | cut -d ":" -f5
你也可以像这样使用grep try:
echo " 1:2:3:4:5" | grep -o '[^:]*$'
一个方法:
var1="1:2:3:4:5"
var2=${var1##*:}
另一个,使用数组:
var1="1:2:3:4:5"
saveIFS=$IFS
IFS=":"
var2=($var1)
IFS=$saveIFS
var2=${var2[@]: -1}
还有一个数组:
var1="1:2:3:4:5"
saveIFS=$IFS
IFS=":"
var2=($var1)
IFS=$saveIFS
count=${#var2[@]}
var2=${var2[$count-1]}
使用Bash(版本>= 3.2)正则表达式:
var1="1:2:3:4:5"
[[ $var1 =~ :([^:]*)$ ]]
var2=${BASH_REMATCH[1]}
sed中的正则表达式匹配是贪婪的(总是到最后一个出现),你可以在这里使用它:
$ foo=1:2:3:4:5
$ echo ${foo} | sed "s/.*://"
5