Рассматривать диктовку как список с четным числом элементов (которое оно есть)
lsort -integer -decreasing -stride 2 -index {end end} $b
h4 {tP 50} h3 {tP 40} h2 {tP 30} h1 {tP 20}
Первый «конец» - это доступ к последнему элементу шага, второй » end "- это доступ к последнему элементу этого индекса.
Вы можете сделать это в 8.5
set temp [list]
set sorted [dict create]
dict for {key value} $b {
lappend temp [list $key $value]
}
foreach pair [lsort -integer -decreasing -index {end end} $temp] {
dict set sorted {*}$pair
}
, только что увидев ваш отредактированный комментарий: да, конечно, это изменится. Вот немного преобразования Шварца:
% set b {h1 {tP 20 lp 1} h2 {tP 30 lp 2} h3 {tP 40 lp 3} h4 {tP 50 lp 4} }
h1 {tP 20 lp 1} h2 {tP 30 lp 2} h3 {tP 40 lp 3} h4 {tP 50 lp 4}
% set temp [list]
% dict for {key subdict} $b {lappend temp [list [dict get $subdict tP] $key $subdict]}
% set sorted [dict create]
% foreach tuple [lsort -int -decr -index 0 $temp] {dict set sorted {*}[lrange $tuple 1 end]}
% set sorted
h4 {tP 50 lp 4} h3 {tP 40 lp 3} h2 {tP 30 lp 2} h1 {tP 20 lp 1}