TASdvlper has asked for the wisdom of the Perl Monks concerning the following question:

Hey all,

Hopefully a easy one for the experts here ...

I would like to daily parse your a nightly dump file. I have the code written to parse it if it's a "csv" file (I did a save as ...), but currently it's in "xls" format. So, is there any quick way or something I can leverage, where I can change the format of a xls file to csv format so I can fully automate this process. I couldn't find anything on CPAN

Thanks in advance.

  • Comment on Changing a file from XLS format to CSV.

Replies are listed 'Best First'.
Re: Changing a file from XLS format to CSV.
by kwaping (Priest) on Sep 21, 2005 at 22:02 UTC
Re: Changing a file from XLS format to CSV.
by sk (Curate) on Sep 21, 2005 at 21:58 UTC
Re: Changing a file from XLS format to CSV.
by davidrw (Prior) on Sep 22, 2005 at 02:49 UTC
Re: Changing a file from XLS format to CSV.
by InfiniteSilence (Curate) on Sep 21, 2005 at 23:41 UTC
    Try using the code here: 487805

    Celebrate Intellectual Diversity

Re: Changing a file from XLS format to CSV.
by radiantmatrix (Parson) on Sep 22, 2005 at 15:23 UTC

    I wrote a program to do exactly this. This is very bad code, as it was mostly a one-off for a batch process, and after I got it working, I moved on. I was also not very good with Perl at the time.

    #!/usr/bin/perl use strict; use warnings; use Spreadsheet::ParseExcel::Simple; use Text::CSV_XS; use IO::File; use File::Spec; for (@ARGV) { for (glob $_) { next unless m/\.xls$/i; next unless -r $_; dump_books($_); } } sub dump_books { my ($vol, $path, $file) = File::Spec->splitpath(shift); my $eBook = Spreadsheet::ParseExcel::Simple->read(File::Spec->catp +ath($vol,$path,$file)); my @sheet = $eBook->sheets; for (0..@sheet-1) { next unless $sheet[$_]->has_data(); my $sfn = $file; $sfn =~ s?\.xls$??i; $sfn.= ((@sheet > 1) ? sprintf(".%02i",$_) : "").'.csv'; my $io = IO::File->new(); $io->open('<'.$sfn) or do { warn "Unable to write to $sfn"; next; }; my $csv = Text::CSV->new; while ($sheet[$_]->has_data) { my @row = $sheet[$_]->next_row; $csv->print($io, \@row); } $io->close; } }

    This only really works with ActiveState Perl, but could be tweaked by altering the parameters to the Text::CSV_XS new() call. There's lots of error handling and process improvement that could go on here, and it will fail miserably on complex XLS books.

    On the upside, each sheet in an Excel book will end up in its own CSV file. Hopefully this will give you a place to start.

    <-radiant.matrix->
    Larry Wall is Yoda: there is no try{} (ok, except in Perl6; way to ruin a joke, Larry! ;P)
    The Code that can be seen is not the true Code
    "In any sufficiently large group of people, most are idiots" - Kaa's Law