perl去除重復(fù)內(nèi)容的腳本代碼(重復(fù)行+數(shù)組重復(fù)字段)
假如有這樣的一段序列:
1 2
1 2
2 1
1 3
1 4
1 5
4 1
我們需要得到如下的結(jié)果:
1 3
1 5
2 1
4 1
那么,請(qǐng)借助以下的perl腳本來(lái)實(shí)現(xiàn)。
代碼一:
#!/bin/perl
use strict;
use warnings;
my $filename;
my %hash;
my @information;
my $key1;
my $key2;
print "please put in the file like this f:\\\\perl\\\\data.txt\n";
chomp($filename=<STDIN>);
open(IN,"$filename")||die("can not open");
while(<IN>)
{
chomp;
@information=split/\s+/,$_;
if(exists $hash{$information[0]}{$information[1]})
{
next;
}
else
{
$hash{$information[0]}{$information[1]}='A';
}
}
close IN;
open(IN,"$filename")||die("can not open");
while(<IN>)
{
@information=split/\s+/,$_;
if(exists $hash{$information[1]}{$information[0]})
{
delete $hash{$information[0]}{$information[1]}
}
else
{
next;
}
}
close IN;
open(OUT,">f:\\A_B_result.txt")||die("can not open");
foreach $key1 (sort{$a<=>$b} keys %hash)
{
foreach $key2 (sort{$a<=>$b} keys %{$hash{$key1}})
{
print OUT "$key1 $key2\n";
}
}
close OUT;
代碼二:
如果有一個(gè)文件data有10G大,但是有好多行都是重復(fù)的,需要將該文件中重復(fù)的行合并為一行,那么我們需要用什么辦法來(lái)實(shí)現(xiàn)
cat data |sort|uniq > new_data #該方法可以實(shí)現(xiàn),但是你需要花上好幾個(gè)小時(shí)。結(jié)果才能出來(lái)。
下面是一個(gè)使用perl腳本來(lái)完成此功能的小工具。原理很簡(jiǎn)單,創(chuàng)建一個(gè)hash,每行的內(nèi)容為鍵,值由每行出現(xiàn)的次數(shù)來(lái)填充,腳本如下;
#!/usr/bin/perl
# Author :CaoJiangfeng
# Date:2011-09-28
# Version :1.0
use warnings;
use strict;
my %hash;
my $script = $0; # Get the script name
sub usage
{
printf("Usage:\n");
printf("perl $script <source_file> <dest_file>\n");
}
# If the number of parameters less than 2 ,exit the script
if ( $#ARGV+1 < 2) {
&usage;
exit 0;
}
my $source_file = $ARGV[0]; #File need to remove duplicate rows
my $dest_file = $ARGV[1]; # File after remove duplicates rows
open (FILE,"<$source_file") or die "Cannot open file $!\n";
open (SORTED,">$dest_file") or die "Cannot open file $!\n";
while(defined (my $line = <FILE>))
{
chomp($line);
$hash{$line} += 1;
# print "$line,$hash{$line}\n";
}
foreach my $k (keys %hash) {
print SORTED "$k,$hash{$k}\n";#改行打印出列和該列出現(xiàn)的次數(shù)到目標(biāo)文件
}
close (FILE);
close (SORTED);
代碼三:
通過(guò)perl腳本,刪除數(shù)據(jù)組中重復(fù)的字段
#!/usr/bin/perl
use strict;
my %hash;
my @array = (1..10,5,20,2,3,4,5,5);
#grep 保存符合條件的元素
@array = grep { ++$hash{$_} < 2 } @array;
print join(" ",@array);
print "\n";
相關(guān)文章
perl運(yùn)算符使用介紹與簡(jiǎn)單應(yīng)用
本文向大家簡(jiǎn)單介紹一下Perl語(yǔ)法中Perl運(yùn)算符的概念,Perl語(yǔ)言中Perl運(yùn)算符有很多值得學(xué)習(xí)的地方,這里和大家分享一下它的概念和用法2013-03-03
Perl Mysql數(shù)據(jù)庫(kù)操作實(shí)現(xiàn)代碼
對(duì)于perl操作mysql的步驟,說(shuō)的比較詳細(xì),建議大家好好看看,參考2009-01-01
Perl語(yǔ)言的循環(huán)實(shí)現(xiàn)方法小結(jié)
Perl語(yǔ)言中提供了多種循環(huán)結(jié)構(gòu),包括for、while、do...while和foreach循環(huán),每種循環(huán)都有其特定的應(yīng)用場(chǎng)景和用法,循環(huán)控制語(yǔ)句如last、next和redo進(jìn)一步提升了循環(huán)的靈活性,通過(guò)靈活運(yùn)用這些循環(huán),可以編寫(xiě)高效而簡(jiǎn)潔的代碼,感興趣的朋友跟隨小編一起看看吧2025-01-01
冒充su ,perl寫(xiě)的su.pl盜取root密碼
backtrack3里面/pentest/housekeeping里面有個(gè)超囧的偷root密碼的東西,冒充su ,perl寫(xiě)的,管理員輸入密碼的時(shí)候還直接回顯2008-09-09
使用腳本實(shí)現(xiàn)自動(dòng)清除指定文件夾下丟失鏈接文件的符號(hào)鏈接
這篇文章主要介紹了使用腳本實(shí)現(xiàn)自動(dòng)清除指定文件夾下丟失鏈接文件的符號(hào)鏈接,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02

