Распространение файла листа в базу данных в скрипте Perl

Я новичок в Perl. Мне нужно прочитать файл Excel и вставить в базу данных.. Вот мой пробный код:

#!/usr/bin/perl -w
use DBI;
use warnings;
my $dbh = DBI->connect("DBI:mysql:database=afscp;host=135.75.60.120;    mysql_socket=/var/lib/mysql/mysql.sock","blrdev_rw","W.mZk8", {'RaiseError'  => 1});
my $insert_table_2= $dbh->prepare(q{INSERT INTO employee_perl  (emp_id,first_nm,last_nm,team_code) VALUES (?, ?,?,?)}) or die $dbh->errstr;
open (FILE, "Excel/Book1.xls") or die "Couldn't read file: $!"; 

while (<FILE>)
    {
        chomp;
        my @fields = split(',', $_);

        my $emp_id = shift(@fields);
        my $fname = shift(@fields);
        my $lname = shift(@fields);
       my $team_code = shift(@fields);      
       $insert_table_2->execute($emp_id,$fname,$lname,$team_code) or   die        $dbh->errstr;
    }

close (FILE);  
$dbh->disconnect();

2 ответа

CPAN модуль Spreadsheet::ParseExcel твой друг читать Excel Из документа:

#!/usr/bin/perl -w
use strict;
use Spreadsheet::ParseExcel;
my $parser   = Spreadsheet::ParseExcel->new();
my $workbook = $parser->parse('Book1.xls');
if ( !defined $workbook )
{
    die $parser->error(), ".\n";
}
for my $worksheet ( $workbook->worksheets() )
{
    my ( $row_min, $row_max ) = $worksheet->row_range();
    my ( $col_min, $col_max ) = $worksheet->col_range();

    for my $row ( $row_min .. $row_max )
    {
        for my $col ( $col_min .. $col_max )
        {
            my $cell = $worksheet->get_cell( $row, $col );
            next unless $cell;

            print "Row, Col    = ($row, $col)\n";
            print "Value       = ", $cell->value(),       "\n";
            print "Unformatted = ", $cell->unformatted(), "\n";
            print "\n";
        }
    }
}

Вы, вероятно, выиграете от хорошей работы, которую поделились на CPAN для этого: введите описание ссылки здесь. Если вы используете ОС GNU/Linux, вы можете проверить, какие модули доступны в виде скомпилированных пакетов (например, вы можете установить с помощью aptitude или emerge или MacPorts, например).

Также вам следует учитывать, что Excel - это программное обеспечение, поддерживающее несколько форматов электронных таблиц, с несколькими версиями для каждого.

В некоторых бизнес-сценариях вы можете рассмотреть возможность подключения электронных таблиц к какому-либо серверу РСУБД, чтобы файлы Excel превратились в интерфейс для общего хранилища данных.

Другие вопросы по тегам