Perl File Operation
Jump to navigation
Jump to search
A Perl File Operation is a Perl operation that is a file operation.
- Context:
- It can range from being a Perl File Open Operation to being a Perl File Close Operation.
- It can range from being a Perl File Read Operation to being a Perl File Write Operation (such as a Perl file append operation).
- It can range from being a Perl File Metadata Operation.
- Example(s):
open my $io, “<-" or die "NO STDIN: $!" ;
while (<$io>) { … }
close $io ;
- Counter-Example(s):
- See: Perl Coding Example.
References
Examples
- Reading & Writing Files
Just reading from a file
open my $io, “<-" or die "NO STDIN: $!" ; while (<$io>) { … } close $io ; open FILE, “<file.txt" or die $!; while (FILE) print $_ ; }
Mixed Read & Write
# Read from one file and write its contents into another file. my $infile = 'foo.txt'; my $outfile = 'bar.txt'; open IN, “< $infile" or die "Can't open $infile : $!"; open OUT, "> $outfile" or die "Can't open $outfile : $!"; print OUT <IN>; close IN; close OUT;
- Subroutine-based
Subroutine to open a file for writing and write into it.
sub read_file { my ($f ) = @_; open F, “< $f" or die "Can't open $f : $!"; my @f = <F>; close F; return wantarray ? @f : \@f; }
Subroutine to open a file for writing and write into it.
sub write_file { my ($f, @data ) = @_; @data = () unless @data; open F, "> $f" or die "Can't open $f : $!"; print F @data; close F; }
- File Open Codes
# Shorthand Flags: Entities Definition < or r Read Only Access > or w Creates, Writes, and Truncates >> or a Writes, Appends, and Creates +< or r+ Reads and Writes +> or w+ Reads, Writes, Creates, and Truncates +>> or a+ Reads, Writes, Appends, and Creates
- File Management
Rename a File
rename ("/usr/test/file1.txt", "/usr/test/file2.txt" );
Delete a file
unlink ("/usr/test/file1.txt");
- Misc
sysopen() instead of open()
- The sysopen function is similar to the main open function, except that it uses the system open() function, using the parameters supplied to it as the parameters for the system function. For example, to open a file for updating, emulating the +<filename format from open:
sysopen(DATA, "file.txt", O_RDWR);
Fcntl module
use Fcntl; # Import standard fcntl.h constants. use Fcntl ":flock"; # Import LOCK_* constants. use Fcntl ":seek"; # Import SEEK_CUR, SEEK_SET, SEEK_END. use Fcntl ":mode"; # Import S_* stat checking constants. use Fcntl ":Fcompat"; # Import F* constants.
O_ Flags includes in Fcntl
module
Value Definition O_RDWR Read and Write O_RDONLY Read Only O_WRONLY Write Only O_CREAT Create the file O_APPEND Append the file O_TRUNC Truncate the file O_EXCL Stops if file already exists O_NONBLOCK Non-Blocking usability
Choose between STDIN or file
my $file = shift @ARGV; my $ifh; my $is_stdin = 0; if (defined $file){ open $ifh, “<", $file or die $!; } else { $ifh = *STDIN; $is_stdin++; } while (<$ifh>){ # Process } close $ifh unless $is_stdin;
- Directory-based operations
Read a directory's files (shortcut with pattern matching).
my @list = <"/usr/bin/*e"> ; # @list = glob("*e*") ;
Load all files in a directory into the @files array
# load all files in a director into the @files array my $dirToRead = "/usr/bin" ; opendir(DIR, $dirToRead) or die "can't open dir $dirToRead: $!" ; my @files = readdir(DIR); closedir(DIR); # build a unsorted list from the @files array: foreach $file (@files) { next if ($file eq "." or $file eq ".."); print $file ; }
another example
my $dirToRead = "/usr/bin" ; opendir(MYDIR, $dirToRead) or die "can't open dir $dirToRead: $!" ; #my @dirContents = grep(!/^\.\.?$/, readdir(MYDIR)) ; my @dirContents = grep {!/^\.\.?$/ && /p$/} readdir(MYDIR) ; print "Files in $dirToRead:\n" ; foreach my $file (@dirContents ) { next if $file =~ /^\.\.?$/ ; # another way to skip . and .. print "$file \n" if -T "$dirToRead/$file" ; # if the file is a {T}ext file. } closedir(MYDIR) ;
a subroutine approach
use DirHandle ; sub plainFiles { my $dir = shift; my $dh = DirHandle->new($dir) or die "can't opendir $dir: $!" ; return sort # sort pathnames grep { -f } # chose only "plain" files map { "$dir/$_" } # create full paths grep { !/^\./ } # filter out dot files $dh->read(); # read all entries }
- JSON-based operations
use JSON; # imports encode_json, decode_json, to_json and from_json. # simple and fast interfaces (expect/generate UTF-8) $utf8_encoded_json_text = encode_json $perl_hash_or_arrayref; $perl_hash_or_arrayref = decode_json $utf8_encoded_json_text; # OO-interface $json = JSON->new->allow_nonref; $json_text = $json->encode( $perl_scalar ); $perl_scalar = $json->decode( $json_text );