1

为下一个 perl 脚本寻找一个漂亮(短而优雅)的衬里:

use strict;
use warnings;

my %all;
while(<DATA>) {
    chomp;
    my ($name, $x, $path) = split /\s+/;
    push @{$all{$path}}, $name;
}
foreach my $path (sort keys %all) {
    my $cnt = scalar @{$all{$path}};
    print "$path $cnt @{$all{$path}}\n" if $cnt > 1;
}
__DATA__
Atxt  x     a/b/c
Btxt x a/d/x
Ctxt x i/t/a
Dtxt x i/y/a
Etxt  x     i/t/a
Ftxt x a/d/x
Gtxt x a/d/x

ofc,单行应该从 STDIN 而不是从 DATA 读取。

简而言之,该脚本读取 3 个字段(namexpath),并应以以下形式输出重复路径的摘要:path dup_count name1 ... namex. 每个name都是不同的。

所以,寻找类似的东西:

my_command | perl -F '\s+' -nle 'shorter_variant_of_the_above_script'
4

1 回答 1

2

可能有一些方法可以缩短它,但这里有一个尝试:

perl -lane 'push@{$h{$F[2]}},$F[0]}{map{$n=@v=@{$h{$_}};print"$_ $n @v"if$n>1}keys%h'

输出提供的数据:

a/d/x 3 Btxt Gtxt Ftxt
i/t/a 2 Etxt Ctxt
于 2012-06-27T11:12:16.843 回答