X-Git-Url: http://git.rot13.org/?p=MARC-Fast;a=blobdiff_plain;f=scripts%2Fdump_fastmarc.pl;h=f9e96f2fba8d0b90ce5e224dc8761a60da066704;hp=5581b897c04c6b47933217db815e6cd5f8910be4;hb=01dc793451bb00d0a95e6b2e70ee0e8882bdf0b7;hpb=5c5233ec1192462b4f0e5d30ba274f1b09cc69fc diff --git a/scripts/dump_fastmarc.pl b/scripts/dump_fastmarc.pl index 5581b89..f9e96f2 100755 --- a/scripts/dump_fastmarc.pl +++ b/scripts/dump_fastmarc.pl @@ -1,27 +1,73 @@ #!/usr/bin/perl -w use strict; -use blib; +use lib 'lib'; use MARC::Fast; +use Getopt::Std; +use Data::Dump qw/dump/; -use Data::Dumper; +=head1 NAME -my $file = shift @ARGV || die "usage: $0 file.marc\n"; -my $debug = shift @ARGV; +dump_fastmarc.pl - display MARC records + +=head2 USAGE + + dump_fastmarc.pl /path/to/dump.marc + +=head2 OPTIONS + +=over 16 + +=item -o offset + +dump records starting with C + +=item -l limit + +dump just C records + +=item -h + +dump result of C on record + +=item -d + +turn debugging output on + +=back + +=cut + +my %opt; +getopts('do:l:h', \%opt); + +my $file = shift @ARGV || die "usage: $0 [-o offset] [-l limit] [-h] [-d] file.marc\n"; my $marc = new MARC::Fast( marcdb => $file, - debug => $debug, + debug => $opt{d}, ); -print STDERR "$file has ",$marc->count," records...\n\n"; -for my $mfn (1 .. $marc->count) { +my $min = 1; +my $max = $marc->count; + +if (my $mfn = $opt{n}) { + $min = $max = $mfn; + print STDERR "Dumping $mfn only\n"; +} elsif (my $limit = $opt{l}) { + print STDERR "$file has $max records, using first $limit\n"; + $max = $limit; +} else { + print STDERR "$file has $max records...\n"; +} + +for my $mfn ($min .. $max) { my $rec = $marc->fetch($mfn) || next; + print "rec is ",dump($rec) if ($opt{d}); print "REC $mfn\n"; - foreach my $f (keys %{$rec}) { - print "$f\t",$rec->{$f},"\n"; - } - print "\n"; + print $marc->last_leader,"\n"; + print $marc->to_ascii($mfn),"\n"; + print "hash is ",dump($marc->to_hash($mfn, include_subfields => 1)) if ($opt{h}); }