假设我有一个字符串,比如
s1="sxfn://xfn.oxbr.ac.uk:8843/xfn/mech2?XFN=/castor/
xf.oxbr.ac.uk/prod/oxbr.ac.uk/disk/xf20.m.ac.uk/prod/v1.8/pienug_ib-2/reco_c21_dr3809_r35057.dst"或
s2="sxfn://xfn.gla.ac.uk:8841/xfn/mech2?XFN=/castor/
xf.gla.ac.uk/space/disk1/prod/v1.8/pienug_ib-2/reco_c21_dr3809_r35057.dst"我希望在我的脚本中提取从prod/开始的最后一部分,即"prod/v1.8/pienug_ib-2/reco_c21_dr3809_r35057.dst“。请注意,$s1包含两次出现的"prod/“。
在bash中,最优雅的方式是什么?
发布于 2016-08-05 23:16:16
使用BASH字符串操作,您可以执行以下操作:
echo "prod/${s1##*prod/}"
prod/v1.8/pienug_ib-2/reco_c21_dr3809_r35057.dst
echo "prod/${s2##*prod/}"
prod/v1.8/pienug_ib-2/reco_c21_dr3809_r35057.dst发布于 2016-08-05 23:15:09
使用awk (它在这方面有点强大,但如果您有一个充满这些字符串的文件,那么它可能会有所帮助:
echo "sxfn://xfn.gla.ac.uk:8841/xfn/mech2?XFN=/castor/xf.gla.ac.uk/space/disk1/prod/v1.8/pienug_ib-2/reco_c21_dr3809_r35057.dst" | awk -F"\/prod" '{print "/prod"$NF}'这就是用'/prod‘拆分字符串,然后打印出'/prod’分隔符和字符串中的最后一个标记($NF)
发布于 2016-08-05 23:18:56
sed可以很好地做到这一点:
s1="sxfn://xfn.oxbr.ac.uk:8843/xfn/mech2?XFN=/castor/xf.oxbr.ac.uk/prod/oxbr.ac.uk/disk/xf20.m.ac.uk/prod/v1.8/pienug_ib-2/reco_c21_dr3809_r35057.dst"
echo "$s1" | sed 's/.*\/prod/\/prod/'这依赖于.*部分的早期匹配。
https://stackoverflow.com/questions/38792555
复制相似问题