有关perl文件操作的一些例子,供大家学习参考。
删除文件
使用unlinke函数,比如unlink $file, unlink $file1, $file2, $file3
打开文件
使用三参数的形式打开文件,这样非常便于区分模式和文件名,perl 5.6之后的版本都支持这种方式。
#Open the 'txt' file for reading
open FH, '<', "$file_name.txt" or die "Error:$!n";
#Open the 'txt' file for writing. Creates the #file_name if it doesn't already exist #and will delete/overwrite a pre-existing file of the same name
open FH, '>', "$file_name.txt" or die "Error:$!n";
#Open the 'txt' file for appending. Creates the #file_name if it doesn't already exist
open FH, '>>', "$file_name.txt" or die "Error:$!n";
#Open the 'txt' file for a 'read/write'. #Will not create the file if it doesn't #already exist and will not delete/overwrite #a pre-existing file of the same name
open FH, '+<', "$file_name.txt" or die "Error:$!n";
#Open the 'txt' file for a 'read/write'. Will create #the file if it doesn't already exist and will #delete/overwrite a pre-existing file #of the same name
open FH, '+>', "$file_name.txt" or die "Error:$!n";
#Open the 'txt' file for a 'read/append'. Will create #the file if it doesn't already exist and will #not delete/overwrite a pre-existing file #of the same name
open FH, '+>>', "$file_name.txt" or die "Error:$!n";
一次性读入整个文件
使用<>在标量环境下一次读入一行,而在列表环境下一次读入所有行,$/存储的是行分隔符,默认是换行符,我们先将$/改掉,这样就可 以在标量环境下一次读入所有行了(这时已经没有行的概念了,就是读入整个文件),你也可以用列表读入所有行然后再将所有行拼到一起,但那样速度很慢。用完 记得将$/改回来。
#!/usr/bin/perl
use strict ;
use warnings ;
sub test{
open FILE, '<', "d:/code/test.txt" or die $! ;
my $olds = $/ ;
$/ = undef ;
my $slurp = <FILE> ;
print $slurp, "n" ;
$/ = $olds ;
close FILE;
}
&test() ;
也可以使用local关键字来将$/设置为局部变量,这样跳出作用域后,$/又恢复了原来的值。
#!/usr/bin/perl
use strict ;
use warnings ;
sub test{
local $/ ; #??? local $/ = undef ;
open FILE, '<', "d:/code/zdd.txt" or die $! ;
my $slurp = <FILE> ;
print $slurp, "n" ;
}
&test() ;
1;
最好的方法是使用模块,这样比自己写安全,File::Slurp、IO::All都可以的。
打开文件请用双引号
open文件时,如果文件名有变量替换,最好用双引号而不是单引号,因为单引号无视变量内插。
文件句柄作参数
假设有一个函数test,它有一个参数,是某个文件句柄,那么该如何传递这个参数呢?
方法一,传递参数时,在句柄前面加*
方法二,使用open my $FILE的形式打开文件