perl 文件/路径 读写删

前端之家收集整理的这篇文章主要介绍了perl 文件/路径 读写删前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

example8:套路模板:

8.1 读文件:

open ($fdr,"<$file")

#it is so cool,all lines can been read directly in array without while
@lineall=<$fdr>;

8.2 读文件

while (<fdr>)  $line=$_;

8.3 读路径

local *DH;

opendir(DH,$item)

foreach (readdir(DH))

一次性将路径读入数组

my @subdir1=readdir ($dir);

读路径下的文件:
my $subdir="/bld/xyz/toolgeneric/328";
@files=glob("$subdir/*/*");


example3: remove folder and file which is data time before one year

#!/opt/exp/bin/perl -w
use File::Path;
my $subdir="/home/coolclf/rje/apaloads";
@files=glob("$subdir/*");
foreach my $file (@files) {
        my $mtime = (stat $file)[9];
        my @t = localtime $mtime;
       $date = sprintf "%02u/%02u/%02u %02u:%02u:%02u",$t[4] + 1,$t[3],$t[5] % 100,$t[2],$t[1],$t[0]; ####get file time status
       print $date,"\n"; 
        my $a = ($t[5] % 100);
        if ($a<13) {
        #       unlink $file;             #only remove file
                print "line15:$file \n";
        #       system("rm -rf $file");        #method 1 :remove folder
#               rmtree("$file");             #methold 2:remove folder
                unlink <$file/*>;            #method 3:remove folder
                rmdir $file;
        }
}

example4:remove.pl 有数字比较和unless 和rm folder和时间

 #!/opt/exp/bin/perl -w

use File::Path;
my $subdir="/opt/cool2b";
my @files=glob("$subdir/*");

foreach my $file (@files) {
#print "file=$file\n";
@array=stat("$file");
my $mtime = (stat $file)[9];
my @t = localtime $mtime;
my $year = ($t[5] % 100);

# print ("line13:year=$year;$t[5]\n");
# if ( $year eq "9" || $year eq "10" || $year eq "11" || ) {
if ( $year > 8 && $year < 10 ) {
print "line15:file=$file\n";
rmdir $file;
}
#$date = sprintf "%02u/%02u/%02u %02u:%02u:%02u",$t[0];
# print $date,"\n";

$uid=$array[4];
# my $name="";
$name=(getpwuid $uid)[0];
# ($name,$passwd,$uid,$gid,$quota,# $comment,$gcos,$dir,$shell) = getpwuid($uid);
#if ( defined ($name) ) {
unless ( defined ($name) ) {
# print ("file=$file;uid=$uid;name=$name\n");
# print ("line25:file=$file\n");
# rmdir $file;
}
# if ($name ne "" ) {
# if ( $name ) {
# print ("file=$file;uid=$uid;name=$name\n");
# }
}

example1: read from command line

钻石操作符<>是perl的读取文件每一行的操作符,是一个整行输入操作符的特例

#!/opt/exp/bin/perl -w
sub say {
        print @_,"\n";
}
my $file =$ARGV[0];
open (my $fh,'<',$file) or die $!;
#@a=<$fh> read file to array; then while read array one by one
while (my $line=<$fh>) {
        if ($line =~ /^bjmcl0(\d\d)/) {
                if ($1>=33 and $1<=63) {
                       #read from $_
                       $line=~s/^/#/;
                }
        }
        # print $line."\n";
        say $line;
}

example2: read and write files

#!/opt/exp/bin/perl
print "\nOpen a text file.\n";
open IN,"<data1.txt";  #read a text file
my @raw=<IN>;           #using @raw store data
chomp(@raw);            #skip enter keys
close(IN);
#print "@raw \n";
my @ref;                #make 2d array
                        #'$#' = length of @raw
for ($i = 0 ; $i <= $#raw ; $i++) {
    my @tmp = split(/\s/,$raw[$i]);
       $ref[$i]=\@tmp; #each line is a refence in @ref
        print "$i;$ref[$i];$tmp[$i] \n";
       
    }

#!/opt/exp/bin/perl -w

open my $fh,'1';
open my $fd,">>","2";
while (my $line=<$fh>) {
	print $fd $line;
}

close ($fh);
close ($fd);
下面这段网络的思路我觉得挺对的:留下来仅供参考

做工程就应该是这样,熟练于一种,应用后组合

"我只知道一种操作符,>,而且每次都只会这么写

open(my $fh,'>','filename') or die $!;

实在搞不清楚那么多的读写符号。我在读写文件时,现在只用 File::Slurp 模块的
read_file write_file 函数接口。

在处理文件时,我很少把输出文件和输入文件设置成一个。因为一旦搞错,数据就毁了。

通常是,设置两个不同的文件,一个读,一个写,经过确认没有问题后,也不敢把原先的文件覆写。而是备份起来。

遍历文件中,对于忽略的行,通常用 next 那么在新文件中就不出现了"

===================================

#!/opt/exp/bin/perl -w
open my $fh,'1-2.txt' or die $!;
while ($line=<$fh>) {
        if ($line=~/felixzh1/) {
                #       $line=~s/.*//g;
                next;
        }
        print $fh1 $line;
}
close $fh

example 6: 遍历subdirectory files

grep /bld/xyz/toolgeneric/328/*/*
<pre code_snippet_id="637883" snippet_file_name="blog_20150407_5_4549377" name="code" class="html">ARGV表示命令行参数
#!/opt/exp/bin/perl -wmy $dir=$ARGV[0];print "$dir \n";my $fd;#my @subdir1=readdir ($dir);#print @subdir1;my $subdir="/bld/xyz/toolgeneric/328";@files=glob("$subdir/*/*");----------------------globe define files#print "line10 @files \n";
 
foreach my $file(@files) {
        print "line12:$file \n";
        my $fh;
        open ($fh,$file) or next;
        while (<$fh>) {
                if (/xyz/) {
                        print "xyz line17 $file:,$_";
                }
        }
        close($fh);
}
</pre><pre code_snippet_id="637883" snippet_file_name="blog_20150407_5_4549377" name="code" class="html">example7:
special variables----INPLACE_EDIT
<p>$^I   内置控制编辑器的值--------------------------仅用于读写同一文件
#!/usr/bin/perl -w
use strict;
$^I = '.bak';
while (<ARGV>) {
    s/felixzh1//g;
print;
}</p>


example 9  find2 查找路径--递归

#!/opt/exp/bin/perl -w

use strict;
use warnings;

sub lsr {
    sub lsr;
    my $cwd = shift;

    local *DH;
    if (!opendir(DH,$cwd)) {
        warn "Cannot opendir $cwd: $! $^E";
        return undef;
    }
    foreach (readdir(DH)) {
        if ($_ eq '.' || $_ eq '..') {
            next;
        }
        my $file = $cwd.'/'.$_;
        if (!-l $file && -d _) {
            $file .= '/';
            lsr($file);
        }
       # process($file,$cwd);
        process($file);
    }
    closedir(DH);
}

my ($size,$dircnt,$filecnt) = (0,0);

sub process($$) {
    my $file = shift;
    print $file,"\n";
    if (substr($file,length($file)-1,1) eq '/') {
        $dircnt++;
    }
    else {
        $filecnt++;
        $size += -s $file;
    }
}

lsr('.');
print "$filecnt files,$dircnt directory. $size bytes.\n";


example 10: find  非递归

use strict;
use warnings;

sub lsr_s {
    my $cwd = shift;
    my @dirs = ($cwd.'/');

    my ($dir,$file);
    while ($dir = pop(@dirs)) {
        local *DH;
        if (!opendir(DH,$dir)) {
            warn "Cannot opendir $dir: $! $^E";
            next;
        }
        foreach (readdir(DH)) {
            if ($_ eq '.' || $_ eq '..') {
                next;
            }
            $file = $dir.$_;         
            if (!-l $file && -d _) {
                $file .= '/';
                push(@dirs,$file);
            }
           # process($file,$dir);
            process($file);
        }
        closedir(DH);
    }
}

my ($size,0);

sub process($$) {
    my $file = shift;
    print $file,"\n";
    if (substr($file,1) eq '/') {
        $dircnt++;
    }
    else {
        $filecnt++;
        $size += -s $file;
    }
}

lsr_s('.');
print "$filecnt file

猜你在找的Perl相关文章