On Friday, November 7, 2003, at 08:23 AM, Paul Hoffman wrote:

On Thursday, November 6, 2003, at 08:45 PM, Leif Andersson wrote:

Assume we have a record with two 035 fields
035 -- $91234567
035 -- $a(XX)12345678

Now, this code will get the 035 $9 subfield:
$subfield  = eval { $record->field('035')->subfield('9') };
@subfields = eval { $record->field('035')->subfield('9') };

But this it will fail getting 035 $a
$subfield  = eval { $record->field('035')->subfield('a') };
@subfields = eval { $record->field('035')->subfield('a') };

I don't see how this can be. Am I missing something?

D'oh! Of course it fails to find the 035 $a subfield -- the call to $record->field('035') in scalar context only returns the *first* 035 field.


My bad.

As for the problem at hand, map and grep are your friends:

   my @fields = $record->field('035');
      # --> list of all 035 fields
   my @possible_subfields = map { $_->subfield('a') } @fields;
      # --> list of results of calling subfield('a') on all 035 fields
   my @subfields = grep { defined } @possible_subfields;
      # --> existing 035 $a subfields only

Or, more succinctly:

@subfields = grep { defined } map { $_->subfield('a') } @fields;

Most Perl programmers are familiar with this idiom, so I wouldn't worry about it being hard to understand.

Paul.

-----Ursprungligt meddelande-----
Från: Paul Hoffman [mailto:[EMAIL PROTECTED]
Skickat: den 6 november 2003 22:30
Till: Leif Andersson
Kopia: [EMAIL PROTECTED]
Ämne: Re: Return values from MARC::Record


On Thursday, November 6, 2003, at 01:14 PM, Leif Andersson wrote:


With the same BAD record we try $subfield = eval {
$record->field($tag)->subfield($sub) }
This is the only case where we have to put the code in eval.
Should MARC:: take care of the eval for us? I am beginning to think so.

No, it can't. Just add your own error checking, something like this for example:

    my $field = $record->field($tag) || die "No tag '$tag' in record";
    $subfield = $field->subfield($sub);

MARC::Record::field has no way of knowing that your code will invoke
the method 'subfield' on the value it returns.  You could also do it
like this if you want to keep things concise:

    $subfield = ($record->field($tag) || die "No tag '$tag' in
record")->subfield($sub);

But that's getting a wee bit obfuscated.

Paul.

-- Paul Hoffman :: Taubman Medical Library :: Univ. of Michigan [EMAIL PROTECTED] :: [EMAIL PROTECTED] :: http://www.nkuitse.com/


--
Paul Hoffman :: Taubman Medical Library :: Univ. of Michigan
[EMAIL PROTECTED] :: [EMAIL PROTECTED] :: http://www.nkuitse.com/



Reply via email to