Beefy Boxes and Bandwidth Generously Provided by pair Networks
laziness, impatience, and hubris
 
PerlMonks  

Re: Displaying records from a flat file?

by gnat (Beadle)
on Jun 27, 2000 at 18:27 UTC ( [id://20003]=note: print w/replies, xml ) Need Help??


in reply to Displaying records from a flat file?

Three options for you:

  1. Build an index of line numbers to offsets.
  2. Use DB_File's DB_RECNO interface to tie the text file to a hash.
  3. Read through the file each time.
Indexing is easy (code untested, as usual. You can find tested similar code in the Perl Cookbook):
open(IDX, "> index") or die; open(DAT, "< datafile") or die; $pos = 0; do { printf IDX "%8d" $pos; $line = <DAT>; $pos = tell(DAT); } while (defined $line); close(IDX); close(DAT);
and to use it:
open(IDX, "< index") or die; open(DAT, "< datafile") or die; # assume $lnum is the line number to go to seek(IDX, 8*$lnum, 0) or die; read(IDX, $offset, 8) or die; seek(DAT, $offset, 0) or die; # now DAT filehandle is positioned to read the # record you wanted
The DB_RECNO interface from DB_File is certainly easier to use, but it's probably not as efficient as it can't keep the index on disk as my code here does.

Hope this gives you some pointers.

Nat

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://20003]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others chanting in the Monastery: (4)
As of 2024-04-20 08:15 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found