次のコードを実行すると、printf ステートメントの出力に配列の順序が正しくないことがわかります。declare ステートメントでは、Source 項目が Destination の前に宣言されており、出力では逆になっています。
YELLOW=$'\e[93m'
declare -A OP=( [Description]="remote to destination" [Source]="/var/www" [Destination]="/foo/bar" [Log]="my.log" [Email]="me@here" );
NO_COLS=`tput cols`
COLS_PER_COL=$(($NO_COLS/3))
PRINT_FORMAT="%"$COLS_PER_COL"s%""s\n"
for i in "${!OP[@]}"; do
printf $PRINT_FORMAT "$i :" " $YELLOW${OP[$i]}$ENDCOL"
done ;
出力は次のようになります
Description : remote to destination
Destination : /foo/bar
Source : /var/www
Log : my.log
Email : me@here
ここで何が起こっているのか、または配列宣言に従って適切な順序を実現するにはどうすればよいのか、誰か教えてもらえますか?
答え1
(および他の言語の)連想配列では、bash
宣言内の要素の順序は保持されません。
宣言の順序を追跡するために別の連想配列を追加できます。
YELLOW=$'\e[93m'
declare -A OP=( [Description]="remote to destination"
[Source]="/var/www"
[Destination]="/foo/bar"
[Log]="my.log"
[Email]="me@here" )
declare -A IP=( [1]="Description"
[2]="Source"
[3]="Destination"
[4]="Log"
[5]="Email" );
NO_COLS="$(tput cols)"
COLS_PER_COL="$((NO_COLS/3))"
PRINT_FORMAT="%${COLS_PER_COL}s%s\n"
for i in "${!IP[@]}"; do
k=${IP[$i]}
printf "$PRINT_FORMAT" "$k :" " $YELLOW${OP[$k]}$ENDCOL"
done