Ah, right you are. I thought DB_File was a method exported by MLDBM rather than a different module. I found and installed that, but I'm still getting this error "Argument "2.121_08" isn't numeric in subroutine entry at C:/Perl/site/lib/MLDBM/Serializer/Data/Dumper.pm line 5." Any idea what that's about? | [reply] |
It might be time for you to show some code -- in particular, what you have on the same line with use MLDBM and what the tie statement looks like, along with anything else relevant to the latter.
Now that you have DB_File installed, you could also test what happens when you open/tie your 5-yr-old data file as a plain-vanilla DB_File hash, just to make sure it's still readable, and to get a look at what the keys and values are.
UPDATE: In case it helps, here's a quick/easy way to dump out the contents of a DB_File hash:
use strict;
use DB_File;
my $Usage = "Usage: $0 db_file_name\n";
die $Usage unless ( @ARGV == 1 and -f $ARGV[0] );
my %file_hash;
tie ( %file_hash, 'DB_File', $ARGV[0] )
or die "DB_File: $ARGV[0]: $!";
while ( my ( $key, $val ) = each %file_hash ) {
print "key: $key\n$val\n;\n";
}
untie %file_hash;
Redirect STDOUT to some other file. It will have records delimited by "\n;\n", and each record will have at least two lines of data, the first line being the hash key (preceded by "key: ") and the second line (plus any additional lines preceding "\n;\n") being the value for that key.
(another update: this assumes that your key strings do not contain line-breaks while you values might; in any case, you could also transliterate things to suit your taste -- e.g. s/(\p{IsCntrl})/sprintf("0x{%02x}",ord($1))/ge; or something like that.)
| [reply] [d/l] [select] |
OK I tried to just read it with DB_File as you suggested, and it worked. The code:
use strict;
use MLDBM qw(DB_File);
my $db = 'data_db';
my %records;
my $dbh = tie %records, 'MLDBM', $db or die $!;
my $junk = 1;
Something else interesting: If I set a breakpoint on the last line and run it straight to there, I get the error about Dumper.pm. If I step through the tie statement with the debugger, I don't get the error. WTF? In that case the debugger lists type = exception for both $dbh and %records.
| [reply] [d/l] |
| [reply] |
| [reply] |