windows下Perl如何读取大文件的最后一行(总结)
2020-12-13 03:25
标签:des class blog http ext 文件 Perl中读取文件最后一行的方法很多,比如 (1)将文件读入数组,取最后一个元素 (2)一行一行读入,到最后一行时输出 或者 (3)这个并未尝试过,有兴趣可以试试 http://search.cpan.org/~mjd/Tie-File-0.96/lib/Tie/File.pm (4)以上的方法都需要遍历整个文件,效率较低。下面这个方法是最高效的,特别是文件很大时,方法是: 打开文件,把指针移动到最后面,一个一个字节往前读,直到读到\N为止 文中内容来自:提问http://bbs.chinaunix.net/thread-599099-1-1.html windows下Perl如何读取大文件的最后一行(总结),搜素材,soscw.com windows下Perl如何读取大文件的最后一行(总结) 标签:des class blog http ext 文件 原文地址:http://www.cnblogs.com/Gihub/p/3807248.htmlopen (FILE,"file.txt") or die "$!";
my @arr=
open (FILE,"file.txt") or die "$!";
while (
open (FILE,"file.txt") ;
$a=
DESCRIPTION ^
Tie::File represents a regular text file as a Perl array. Each element in the array corresponds to a record in the file. The first line of the file is element 0 of the array; the second line is element 1, and so on.
The file is not loaded into memory, so this will work even for gigantic files.
Changes to the array are reflected in the file immediately.
Lazy people and beginners may now stop reading the manual.#!/usr/bin/perl -w
use strict;
my $file = shift or die;
my $content = "";
open (F, $file) or die $!;
seek (F, 0, 2); # set handler at the end of $file
until ($content =~ m/\n(.*)\n?$/)
{
my $string;
if (seek (F, -1024, 1)) # backward 1024 bytes
{
my $n = read (F, $string, 1024) or die $!;
$content = $string . $content;
last if ($n
文章标题:windows下Perl如何读取大文件的最后一行(总结)
文章链接:http://soscw.com/essay/27558.html