22 }, { "p.D842Y-6ren">
gpt4 book ai didi

perl - 按内部哈希值对哈希数组的哈希进行排序

转载 作者:行者123 更新时间:2023-12-02 08:36:39 24 4
gpt4 key购买 nike

我很难理解这个问题,我敢肯定这只是今天过于紧张的一个例子。我有一个类似于这样的数据结构:

{
PDGFRA => [
{ "p.N659K" => 22 },
{ "p.D842Y" => 11 },
{ "p.I843_S847>T" => 9 },
{ "p.D842_H845del" => 35 },
{ "p.I843_D846delIMHD" => 24 },
{ "p.I843_D846del" => 21 },
{ "p.D842V" => 457 },
{ "p.N659Y" => 5 },
{ "p.M844_S847del" => 7 },
{ "p.S566_E571>K" => 8 },
{ "p.S566_E571>R" => 50 },
{ "p.V561D" => 54 },
],
}

我想打印出结果,按哈希值反向排序(从大到小),所以最终我得到这样的结果

PDGFRA    p.D842V    457
PDGFRA p.V561D 54
PDGFRA p.S566_E571>R 50
PDGFRA p.D842_H845del 35
.
.
.
etc.

我可以按需要打印数据结构,但我似乎无法弄清楚如何在打印之前对数据进行排序。我试过这样排序:

for my $gene ( sort keys %matches ) {
for my $var ( sort { $a->{$var} <=> $b->{$var} } @{$matches{$gene}} {
print "$var\n";
}
}

但是不管我用$var还是$_好像都不行,提示'$var'没有定义,'$_'是未初始化。我也尝试(真的很可怜!)使用 Schwarzian 变换,但我认为我在这方面还差得很远:

for my $gene ( sort keys %matches ) {
my @sorted =
map { $_->[0] }
sort { $a->[1] <=> $b->[1] }
map { [ $_, $matches{$gene}->{$_} ] } @{$matches{$gene}};
}

有人会介意向我指出正确的方向以按内部哈希值对哈希或哈希数组进行排序吗?

最佳答案

这是一个替代方案。它的工作原理是将 索引 列表排序到数组 @sorted 中,这样您就可以迭代数组切片 @$list[@sorted].

虽然您受到数据格式的阻碍,并且仅在给定单元素散列的情况下提取一对值是很困惑的。

希望对您有所帮助。

use strict;
use warnings;

my %matches = (
PDGFRA => [
{ "p.N659K" => 22 },
{ "p.D842Y" => 11 },
{ "p.I843_S847>T" => 9 },
{ "p.D842_H845del" => 35 },
{ "p.I843_D846delIMHD" => 24 },
{ "p.I843_D846del" => 21 },
{ "p.D842V" => 457 },
{ "p.N659Y" => 5 },
{ "p.M844_S847del" => 7 },
{ "p.S566_E571>K" => 8 },
{ "p.S566_E571>R" => 50 },
{ "p.V561D" => 54 },
],
);

while (my ($key, $list) = each %matches) {

my @sorted = sort {
my ($ka, $va) = %{ $list->[$b] };
my ($kb, $vb) = %{ $list->[$a] };
$va <=> $vb;
} 0 .. $#$list;

for my $item (@$list[@sorted]) {
printf "%s %s %d\n", $key, %$item;
}
}

输出

PDGFRA   p.D842V     457
PDGFRA p.V561D 54
PDGFRA p.S566_E571>R 50
PDGFRA p.D842_H845del 35
PDGFRA p.I843_D846delIMHD 24
PDGFRA p.N659K 22
PDGFRA p.I843_D846del 21
PDGFRA p.D842Y 11
PDGFRA p.I843_S847>T 9
PDGFRA p.S566_E571>K 8
PDGFRA p.M844_S847del 7
PDGFRA p.N659Y 5

更新

在我对 David W 的回答的评论中,我建议使用一种数据结构,它只是一个双元素数组,而不是一个单元素哈希数组。

这就是它的样子。输出与上面的代码相同

use strict;
use warnings;

my %matches = (
PDGFRA => [
[ "p.N659K", 22 ],
[ "p.D842Y", 11 ],
[ "p.I843_S847>T", 9 ],
[ "p.D842_H845del", 35 ],
[ "p.I843_D846delIMHD", 24 ],
[ "p.I843_D846del", 21 ],
[ "p.D842V", 457 ],
[ "p.N659Y", 5 ],
[ "p.M844_S847del", 7 ],
[ "p.S566_E571>K", 8 ],
[ "p.S566_E571>R", 50 ],
[ "p.V561D", 54 ],
],
);

while (my ($key, $list) = each %matches) {

my @sorted = sort { $list->[$b][1] <=> $list->[$a][1] } 0 .. $#$list;

for my $item (@$list[@sorted]) {
printf "%s %s %d\n", $key, @$item;
}
}

关于perl - 按内部哈希值对哈希数组的哈希进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20683953/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com