perl清理电脑上重复的文件--续
续上一篇,利用PERL搜索电脑上重复文件。全源代码:
use File::DirWalk;
use File::Basename;
use Data::Dumper;
use warnings;
use strict;
my$dw= new File::DirWalk;
my%files;
fileparse_set_fstype("MSWin32");
$dw->onFile(
sub {
my ($file) =@_;
push @{$files{basename($file)}->{"Paths"}},$file;
$files{basename($file)}->{"Num"} +=1;
return File::DirWalk::SUCCESS;
}
);
my$hTrace;
open$hTrace,'> Trace.txt';
select$hTrace;
$dw->walk('D:/old/perl');
my@newFiles;
while( my ($k,$v) =each%files)
{
if($v->{"Num"} >1)
{
#print $k."\n";
#print Dumper($v);
push@newFiles,
{
"Name"=>$k,
"Paths"=>$v->{"Paths"},
"Num"=>$v->{"Num"}
}
}
}
#print Dumper(@newFiles);
@newFiles=sort {($a->{"Num"}) <=> ($b->{"Num"})} @newFiles;
print Dumper(@newFiles);
close$hTrace;
use File::Basename;
use Data::Dumper;
use warnings;
use strict;
my$dw= new File::DirWalk;
my%files;
fileparse_set_fstype("MSWin32");
$dw->onFile(
sub {
my ($file) =@_;
push @{$files{basename($file)}->{"Paths"}},$file;
$files{basename($file)}->{"Num"} +=1;
return File::DirWalk::SUCCESS;
}
);
my$hTrace;
open$hTrace,'> Trace.txt';
select$hTrace;
$dw->walk('D:/old/perl');
my@newFiles;
while( my ($k,$v) =each%files)
{
if($v->{"Num"} >1)
{
#print $k."\n";
#print Dumper($v);
push@newFiles,
{
"Name"=>$k,
"Paths"=>$v->{"Paths"},
"Num"=>$v->{"Num"}
}
}
}
#print Dumper(@newFiles);
@newFiles=sort {($a->{"Num"}) <=> ($b->{"Num"})} @newFiles;
print Dumper(@newFiles);
close$hTrace;
标签:
PERL
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?