- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经用头撞墙了几个小时了。
我有一个看起来像这样的数据结构(来自“Data::Dumper”的输出)。这是我自己的错,我在解析一些输入时创建了数据结构。
print Dumper $data;
___OUTPUT___
$VAR = { 'NAME' => {
'id' => '1234',
'total' => 192,
'results' => {
'APPLE' => 48 ,
'KUMQUAT' => 61 ,
'ORANGE' => 33 ,
}
}
}
我想打印一个逗号分隔的列表,首先按“total”排序,然后按“results”数组中每个散列的值排序。
以下代码用于从已存储的数据结构中打印出 CSV。
use strict;
use warnings;
# [...lots of other stuff...]
open (my $fh, >out.csv);
print $fh "Name, ID, Label, Count, Total\n";
foreach ( sort { $data->{$b}->{total} <=> $data->{$a}->{total} }
keys %{$data} )
{
my $name = $_;
foreach (
sort {
$data->{$name}->{results}->{$a} <=> $data->{$name}->{results}
->{$b}
} values %{ $data->{$name}->{results} }
)
{
print $fh $name . ","
. $data->{$name}->{id} . "," . "'"
. $_ . ","
. $data->{$name}->{results}->{$_} . "," . "\n";
}
print $fh $name . ","
. $data->{$name}->{id} . "," . "," . ","
. $data->{$name}->{total} . "\n";
}
close($fh);
这很好,效果很好(除了提醒我为什么不再使用 Perl)。
示例输出如下:
Name, ID, Label, Count, Total
foo, 1234, ORANGE, 33,
foo, 1234, APPLE, 48,
foo, 1234, KUMQUAT, 61,
foo, 1234, , , 142
bar, 1101, BIKE, 20,
bar 1101, , , 20
但是!我注意到我遇到了关键冲突(在“结果”哈希中),由于我需要保留并报告所有数据,我决定尝试将“结果”更改为哈希数组...
print Dumper $data;
___OUTPUT___
$VAR = { 'NAME' => {
'id' => '1234',
'total' => 192,
'results' => [
{ 'APPLE' => 48 },
{ 'KUMQUAT' => 61 },
{ 'ORANGE' => 33 },
{ 'APPLE' => 50 },
]
}
}
不管有没有人读到这么远,我不得不说写下来是相当有治疗作用的,所以我会继续……;-)
对于新的数据结构,排序/打印代码有问题。
use strict;
use warnings;
# [...lots of other stuff...]
open (my $fh, >out.csv);
print $fh "Name, ID, Label, Count, Total\n";
foreach ( sort { $data->{$b}->{total} <=> $data->{$a}->{total} }
keys %{$data} )
{
my $name = $_;
foreach (
sort {
$data->{$name}->{results}->{$a} <=> $data->{$name}->{results}
->{$b}
} values %{ $data->{$name}->{results} }
)
{
# .... HELP ME FOR THE LOVE OF ALL THAT IS GOOD IN THE WORLD! ....
# I'm at the point now where my brain is starting to slowly dribble from my
# ears...
}
print $fh $name . ","
. $data->{$name}->{id} . "," . "," . ","
. $data->{$name}->{total} . "\n";
}
close($fh);
如果你已经读到这里,我向你致敬。如果你能帮忙,我为你鼓掌。
如果有人对数据结构的替代格式有任何建议,请告诉我! (如果您有兴趣......我正在使用“触发器”运算符来捕获源文件的 block ,然后我使用这些 block 逐行创建数据结构。我也调用外部计算某些东西的程序(没有 Perl 等价物)并存储结果。)
谢谢
最佳答案
好的,我只想说一次:结构复杂时总是使用对象
正如您所发现的,您的大脑会在尝试跟踪哈希数组的哈希数组时爆炸。这是创建对象结构的完美理由。如果你永远不会重复使用它也没关系。它使您的编程任务变得容易得多。
以下包花了我大约 30 分钟来编写和调试。如果你使用它,你会为自己省去很多心痛和调试。
作为奖励,当您发现您的错误假设(嘿,每个人都这样做!)您的 RESULT 数组中有多个具有相同键的项目时,您只需修改几行即可轻松定位代码尝试将所有内容保持在一起的整个程序。
我使用了您的数据结构,但我将 RESULTS 设为一个数组,该数组包含一个包含两个项目(标签和数量)而不是哈希的数组。我本可以使用哈希,但是这样,我可以返回一个包含两个项目的数组。现在,我想起来,无论如何都没有理由这样做。
#! /usr/bin/env perl
use warnings;
use strict;
use feature qw(say);
use Data::Dumper;
my %hash;
my $obj;
$obj = structure->new();
$obj->Name("foo");
$obj->Total("foo", 142);
$obj->Id("foo", 1234);
$obj->Push(qw(foo ORANGE 33));
$obj->Push(qw(foo APPLE 48));
$obj->Push(qw(foo APPLE 50));
$obj->Push(qw(foo KUMQUAT 61));
$obj->SortResults("foo");
$obj->Name("bar");
$obj->Total("bar", 20);
$obj->Id("bar", 1100);
$obj->Push(qw(bar BIKE 20));
$obj->SortResults("bar");
say Dumper($obj);
exit 0;
########################################################################
package structure;
use Data::Dumper;
#
# New Structure containing all data
#
sub new {
my $class = shift;
my $self = {};
bless $self, $class;
return $self;
}
#
# Either adds a new name object or returns name object;
#
sub Name {
my $self = shift;
my $name = shift;
if (not defined $self->{$name}) {
$self->{$name}->{ID} = undef;
$self->{$name}->{TOTAL} = undef;
$self->{$name}->{RESULTS} = [];
}
return $self->{$name};
}
#
# Returns a list of Names
#
sub NameList {
my $self = shift;
return keys %{$self};
}
#
# Either returns the id or sets $name's id
#
sub Id {
my $self = shift;
my $name = shift;
my $id = shift;
my $nameObj = $self->Name($name);
if (defined $id) {
$nameObj->{ID} = $id;
}
return $nameObj->{ID};
}
#
# Either returns the total for $name or sets $name's total
#
sub Total {
my $self = shift;
my $name = shift;
my $total = shift;
my $nameObj = $self->Name($name);
if (defined $total) {
$nameObj->{TOTAL} = $total;
}
return $nameObj->{TOTAL};
}
#
# Pushes new product and amount on $name's result list
#
sub Push {
my $self = shift;
my $name = shift;
my $product = shift;
my $amount = shift;
my $nameObj = $self->Name($name);
my @array = ("$name", "$amount");
push @{$nameObj->{RESULTS}}, \@array;
return @array;
}
#
# Pops product and amount on $name's result list
#
sub Pop {
my $self = shift;
my $name = shift;
my $nameObj = $self->Name($name);
my $arrayRef = pop @{$nameObj->{RESULTS}};
return @{$arrayRef};
}
sub SortResults {
my $self = shift;
my $name = shift;
my $nameObj = $self->Name($name);
my @results = @{$nameObj->{RESULTS}};
my @sortedResults = sort {$a->[1] <=> $b->[1]} @results;
my $nameObj->{RESULTS} = \@sortedResults;
return @sortedResults;
}
$obj->SortResults
将对结果进行就地排序,但无论如何您都可以使用它将结果作为排序列表检索。要按总计对项目进行排序,您可以使用:
my @sortedItems = sort {$obj->Total($a) <=> $obj->Total($b)} $obj->NameList();
简而言之,您可以节省自己的时间和清洁女工清理的烂摊子。 (爆炸的大脑很难从墙壁和天花板上擦掉)。
我从经验中了解到,每当您开始谈论包含指向其他散列的数组的散列的散列时,就该创建一个对象来处理困惑了。为这些类型的一次性工作创建对象似乎需要更长的时间,但根据我的经验,您通常可以在 30 分钟内大量制作所需内容并进行测试,这样可以节省您日后数小时的挫败感。
关于perl - 帮助遍历/排序复杂的 Perl 数据结构(HoH with AoH fun),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5873227/
如果我的 Perl 程序使用 Perl 模块,它将如何确定在哪里可以找到包含模块代码的文件? 例如,如果程序包含: use MyModule1; # Example 1 us
我在一个文件中有一些不同格式的数字:8.3、0.001、9e-18。我正在寻找一种简单的方法来读取它们并存储它们而不会损失任何精度。这在 AWK 中很容易,但在 Perl 中是如何完成的呢?我只愿意使
我在一个文件中有一些不同格式的数字:8.3、0.001、9e-18。我正在寻找一种简单的方法来读取它们并存储它们而不会损失任何精度。这在 AWK 中很容易,但在 Perl 中是如何完成的呢?我只愿意使
我正在自学 Perl,并且在我的 Windows 8 64 位系统上安装了 Strawberry。 Strawberry 命令行似乎工作正常,我在 C 驱动器上的 Strawberry 文件夹中创建了
我在 Perl 模块 IO::Socket::SSL 中发现了一个错误,我可能会修复它,但是,我担心测试修复。我从 Debian 下载了源码包(因为我打算为它制作一个 Debian 包或补丁)并查看了
我有一个 perl 文件,它使用了两个 perl 模块 A.pm 和 B.pm。 但是在 B.pm 中我需要调用 A.pm 的子程序。即使我在 A.pm 中使用并尝试使用它,我仍然遇到未定义的错误。
有没有办法在 Perl 运行时加载整个模块?我原以为我用 autouse 找到了一个很好的解决方案,但以下代码无法编译: package tryAutouse2; use autouse 'tryAu
过去,我编写过许多 perl 模块,以及不止一些独立的 perl 程序,但我之前从未发布过多文件 perl 程序。 我有一个几乎处于 beta 阶段的 perl 程序,它将被开源发布。它需要一些数据文
我有 1 个 perl 脚本,我们在其中编写了几个子例程。例子: # Try_1.pl main(); sub main{ --- --- check(); } check { -- --} 现在,
似乎 CPAN 上的一些(很多?)模块部分是使用 XS 在 C 中实现的,如果需要,可以回退到纯 perl 实现。虽然这很聪明,但它显然会损害性能,我想知道它是否会发生,以便我可以解决问题。 有没有一
我对 perl 很陌生。我希望我可以从 perl 安装一些软件包,我这样做是这样的: perl -MCPAN -e 'install VM::EC2' 我猜它由于依赖而失败,它显示: Result:
给定一个 Perl 包 Foo.pm,例如 package Foo; use strict; sub bar { # some code here } sub baz { # more
我有一个用 Perl 编写的测试生成器。它生成连接到模拟器的测试。这些测试本身是用 Perl 编写的,并通过其 API 连接到模拟器。我希望生成的代码是人类可读的,这意味着我希望它能够正确缩进和格式化
我正在学习 Perl,非常新的用户。我可以知道这些 Perl 代码之间有什么区别吗? #!/usr/bin/perl & #!/usr/bin/perl -w 最佳答案 那不是 perl 代码,它是
我不认为这是一个重复的问题。这专门针对 Perl 模块附带的脚本。 通常,在安装多个 Perl 版本时,您可以将 perl 可执行文件标记为版本号 (perl5.32),这样它们就可以在 /whate
我有一个在文件中使用 Blowfish 加密的程序和第二个 perl 程序,它提示输入用于将其解密为字符串的密码,我希望不必将解密的源代码写入硬盘驱动器,尽管将它放在内存中并不是真正的问题,因为运行程
有没有人为 Perl 中的惰性求值列表找到了一个好的解决方案?我尝试了很多方法来改变类似的东西 for my $item ( map { ... } @list ) { } 进入懒惰的评估——例如,通
我安装了多个版本的 Perl。 我已经指定了要使用的版本。但是为了验证,我想从 .pl 脚本本身输出 Perl 的版本。 这可能吗? 在 Perl 脚本中解析“perl --version”的输出似乎
人们还经常问“我怎样才能编译 Perl?”而他们真正想要的是创建一个可以在机器上运行的可执行文件,即使他们没有安装 Perl。 我知道有几种解决方案: perl2exe靛蓝之星 它是商业的。我从未尝试
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 8年前关闭。 Improve this
我是一名优秀的程序员,十分优秀!