2017-08-10 61 views
0

我在检查这三个SUBSTRING是否在STRING中。如何匹配子串,在shell中进行字符串的常规匹配?

STRING:

active 
mac address ec:f4:bb:e1:0c:18 
Link Up - speed 10000 Mbps - full-duplex 
LACP actor_state ACTIVE AGGREGATION SYNC COLLECTING DISTRIBUTING 

SUBSTRING:

  1. 活性
  2. ACTIVE
  3. DISTRIBUTING

我尝试在我的shell脚本使用这些:

dpdkb2_slave0_res=$(/usr/local/bin/ovs-appctl dpdk/bond-show dpdkb2 | sed -n '5,8p') 
dpdkb2_slave1_res=$(/usr/local/bin/ovs-appctl dpdk/bond-show dpdkb2 | sed -n '14,17p') 

s0_active=$(expr index $dpdkb2_slave0_res 'active') 
if [[ -n "$dpdkb2_slave0_res" && $s0_active -ne 0 ]] ; then 
    ok_output "dpdkb2 status is ok:" 
    ok_output "$dpdkb2_res" 

但在4号线,报错:expr的:语法错误

但是,当我在shell中运行expr index $dpdkb2_slave0_res 'active'命令时没关系。

  1. 如何解决这个问题?
  2. 如何做字符串位置,搜索,替换?哪一个最有效,expr{string##}awksed

我不得不说要使用shell很难,shell没有办法处理字符串,shell必须使用awk,sed,grep等工具来处理字符串。我不知道为什么。

最后一个问题:

  • 如何三个世界搭配在一起?我想使用active*ACTIVE*DISTRIBUTING,但awksed都报告错误。
  • +0

    如果只有*检查这三个子字符串是否在STRING *(为你写) - 它可以用一个可实现在线方法 – RomanPerekhrest

    +0

    关于#3 - 'sed -r'/(active | ACTIVE | DISTRIBUTING)/'' – stevesliva

    回答

    0

    您可以实现所有要使用awk做,

    $ awk 'match($0,/ACTIVE/){printf "%d ",RSTART} sub("ACTIVE","xxx",$0)' file 
    18 LACP actor_state xxx AGGREGATION SYNC COLLECTING DISTRIBUTING 
    
    $ awk 'match($0,/active/){printf "%d ",RSTART} sub("active","yyy",$0)' file 
    1 yyy 
    
    $ awk 'match($0,/DISTRIBUTING/){printf "%d ",RSTART} sub("DISTRIBUTING","zzz",$0)' file 
    53 LACP actor_state ACTIVE AGGREGATION SYNC COLLECTING zzz 
    

    简要交代,

    • 每个命令的第一输出将是串的起点,即ACTIVE,active和DISTRIBUTING。
    • 该命令的第二个输出结果将被特定模式替代,即xxx,yyy和zzz。您可以根据您的要求更改为所需的替代品。
    0

    目前尚不清楚您正在寻找解决方案的shell,但从您的示例中,我想您不需要确保符合POSIX标准的东西。

    既然你似乎并不需要串的实际位置,但只有是否显示了子,下面应该工作至少岩组和bash:

    if [[ $dpdkb2_slave0_res == *active* ]] 
    then 
        ok_output "dpdkb2 status is ok:" 
        ... 
    fi 
    

    目前尚不清楚给我你的使用的话一起的意思,但也许你的意思是这样

    if [[ $dpdkb2_slave0_res == *ACTIVE*DISTRIBUTING* ]]