my $input = new WebPAC::Input::CSV(
path => '/path/to/records.csv',
+ header_first => 1,
);
Options:
Default encoding of input file is C<utf-8>
+C<header_first> will use first line as header names.
+
=cut
sub new {
$self->{size} = 0;
+ if ( $self->{header_first} ) {
+ my $line = $csv->getline( $fh );
+ $self->{header_names} = $line;
+ $self->debug( "header_names = ",dump( $self->{header_names} ) );
+ }
+
while ( 1 ) {
my $line = $csv->getline( $fh );
last if $csv->eof;
$rec->{'000'} = [ ++$self->{size} ];
my $col = 'A';
+ my $header_pos = 0;
+
foreach my $cell ( @$line ) {
my $str = eval { Encode::decode_utf8( $cell ) };
if ( $@ ) {
}
$rec->{ $col++ } = $str;
+
+ if ( $self->{header_names} ) {
+ $rec->{ $self->{header_names}->[$header_pos] } = $str;
+ $header_pos++;
+ }
}
push @{ $self->{_rec} }, $rec;