A filehandle is the name for an I/O connection between your Perl process and the operating system. Filehandle names are like label names, but use their own namespace. Like label names, the convention is to use all uppercase letters for filehandle names.
Every Perl program has three filehandles that are automatically opened: STDIN, STDOUT, and STDERR. By default, the
print
and
write
functions write to STDOUT.
Additional filehandles are created using the
open
function:
DATA is the new filehandle that is attached to the external file, which is now opened for reading. You can open filehandles for reading, writing, and appending to external files and devices. To open a file for writing, prefix the filename with a greater-than sign:open (DATA, "numbers.txt");
To open a file for appending, prefix the filename with two greater-than signs:open(OUT, ">outfile");
Theopen(LOGFILE, ">>error_log");
open
function returns true if the file is successfully opened, and false if it failed to open. Opening a file can fail for any number of reasons: a file does not exist, is write-protected, or you don't have permission for a file or directory. However, a filehandle that has not been successfully opened can still be read from (giving you an immediate EOF) or written to, with no noticeable effects.
You should always check the result of
open
immediately and report an error if the operation does not succeed. The
warn
function can report an error to standard error if something goes wrong, and
die
can terminate your program and tell you what went wrong. For example:
Once the file is opened, you can access the data using the diamond operator,open(LOGFILE, "/usr/httpd/error_log") || warn "Could not open /usr/httpd/error_log.\n"; open(DATA, ">/tmp/data") || die "Could not create /tmp/data\n.";
<
filehandle
>. This is the line-input operator. When used on a filehandle in a scalar context, it will return a line from a filehandle as a string. Each time it is called it will return the next line from the filehandle, until it reaches the end-of-file. The operator keeps track of which line it is on in the file, unless the filehandle is closed and reopened, resetting the operator to the top-of-file.
For example, to print any line containing the word "secret.html" from the LOGFILE filehandle:
In a list context, the line-input operator returns a list in which each line is an element. The emptywhile (<LOGFILE>) { print "$_\n" if /secret\.html/; }
<>
operator reads from the ARGV filehandle, which reads the array of filenames from the Perl command line. If
@ARGV
is empty, the operator resorts to standard input.
A number of functions send output to a filehandle. The filehandle must already be opened for writing, of course. In the previous example,
print
wrote to the STDOUT filehandle, even though it wasn't specified. Without a filehandle,
print
defaults to the currently selected output filehandle, which will be STDOUT until you open and select another one in your program. See the
select
function (filehandle version) for more information.
If your program involves more than a couple of open filehandles, you should be safe and specify the filehandles for all of your IO functions:
To close a filehandle, use theprint LOGFILE "======= Generated report $date ======="
close
function. Filehandles are also closed when the program exits.