0

如何e.g. ( "A: 2" "B: 3" "C: 1" )按值对 bash 中的“python 字典样式”数组进行排序?我认为,此代码段将使我的问题更加清楚。

State="Total 4 0 1 1 2 0 0"
W=$(echo $State | awk '{print $3}')
C=$(echo $State | awk '{print $4}')
U=$(echo $State | awk '{print $5}')
M=$(echo $State | awk '{print $6}')
WCUM=( "Owner: $W;" "Claimed: $C;" "Unclaimed: $U;" "Matched: $M" )
echo ${WCUM[@]}

这将简单地打印数组:Owner: 0; Claimed: 1; Unclaimed: 1; Matched: 2

如何对数组(或输出)进行排序,消除任何具有“0”值的对,使结果如下:

Matched: 2; Claimed: 1; Unclaimed: 1

提前感谢您的任何帮助或建议。干杯!!

4

3 回答 3

3

快速而肮脏的想法是(这只是对输出进行排序,而不是对数组进行排序):

echo ${WCUM[@]} | sed -e 's/; /;\n/g' | awk -F: '!/ 0;?/ {print $0}' | sort -t: -k 2 -r | xargs
于 2012-05-26T08:26:13.900 回答
1
echo -e ${WCUM[@]} | tr ';' '\n' | sort -r -k2 | egrep -v ": 0$"

排序和过滤是独立的步骤,所以如果你只喜欢过滤 0 值,那会容易得多。

附加一个

 | tr '\n' ';'

最后再把它变成一行。

nonull=$(for n in ${!WCUM[@]}; do echo ${WCUM[n]} | egrep -v ": 0;"; done | tr -d "\n")

我认为 $W $C $U 没有以分号结尾的充分理由,但 $M 不是,因此我不会使我的代码适应这种区别,而是消除这种特殊情况。如果不可能,我会在 $M 中附加一个临时分号并最终将其删除。

于 2012-05-26T10:13:20.210 回答
0

另一种尝试,使用一些 bash 功能,但仍然需要sort,这是至关重要的:

#! /bin/bash
State="Total 4 1 0 4 2 0 0"
string=$State
for i in 1 2 ; do        # remove unnecessary fields
    string=${string#* }
    string=${string% *}
done

# Insert labels
string=Owner:${string/ /;Claimed:}
string=${string/ /;Unclaimed:}
string=${string/ /;Matched:}

# Remove zeros
string=(${string[@]//;/; })
string=(${string[@]/*:0;/})
string=${string[@]}

# Format
string=${string//;/$'\n'}
string=${string//:/: }

# Sort
string=$(sort -t: -nk2 <<< "$string")
string=${string//$'\n'/;}
echo "$string"
于 2012-05-26T10:10:27.670 回答