awk - AIX / KSH从逗号分隔的行中提取字符串

我想从下面的逗号分隔行中提取“ virtual_eth_adapters”部分:

lpar_io_pool_ids=none,max_virtual_slots=300,"virtual_serial_adapters=0/server/1/any//any/1,1/server/1/any//any/1","virtual_scsi_adapters=166/client/1/ibm/166/0,266/client/2/ibm/266/0",virtual_eth_adapters=116/0/263,proc_mode=shared,min_proc_units=0.5,desired_proc_units=2.0,max_proc_units=8.0

我在ksh中使用AIX。

我发现了awk和-F标志的解决方法,用分隔符分隔字符串,然后打印项目ID。 但是,如果输入字符串更改,则id可能会有所不同...

第一种解决方案:如果您也想在输出中打印字符串virtual_eth_adapters可以请尝试以下方法。

awk '
match($0,/virtual_eth_adapters[^,]*/){
  print substr($0,RSTART,RLENGTH)
}
' Input_file

输出如下。

virtual_eth_adapters=116/0/263


第二种解决方案:如果您只想打印String virtual_eth_adapters值,请尝试执行以下操作。

awk '
match($0,/virtual_eth_adapters[^,]*/){
  print substr($0,RSTART+21,RLENGTH-21)
}
' Input_file

输出如下。

116/0/263

说明:添加代码说明。

awk '                                        ##Starting awk program here.
match($0,/virtual_eth_adapters[^,]*/){       ##Using match function of awk here, to match from string virtual_eth_adapters till first occurrence of comma(,)
  print substr($0,RSTART,RLENGTH)            ##Printing sub-string whose starting value is RSTART and till value of RLENGTH, where RSTART and RLENGTH variables will set once a regex found by above line.
}
' Input_file                                 ##Mentioning Input_file name here.

我确实使用这些方法来中途提取数据。

awk -F'virtual_eth_adapters=' 'NF>1{split($2,a,",");print a[1]}' file
116/0/263

它简短易学。 (无需计数或正则表达式)

  • -F'virtual_eth_adapters='virtual_eth_adapters=分隔行
  • 如果有多个字段(行包含virtual_eth_adapters= ),则NF>1
  • split($2,a,",")将行的最后一部分拆分为一个数组, a分隔,
  • print a[1]打印数组a第一部分

还有一个解决方案(假设字符串的位置)

awk -F\, '{print $7}'

如果仅需要该值,请尝试以下操作:

awk -F\, '{print $7}'|awk -F\= '{print $2}'

也可以通过这种方式获取值:

awk -F\, '{split($7,a,"=");print a[2]}'

转载请注明来自askonline.tech,本文标题:awk - AIX / KSH从逗号分隔的行中提取字符串


 Top