挽星

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

从MySQL中导出XLS数据库工具

来源: 作者: 日期:2007-07-08

【聚杰网PL/SQL】从MySQL中导出XLS数据库工具

 

warn "write to: $ARGV[0]/n";

#生成GB2312编码系统

my $map = Unicode::Map->new("gb2312");

#产生报表

my $report = Spreadsheet::WriteExcel::Big->new("$ARGV[0]") || die "不能生成报表文件:$!";

#创建报表的工作表

my $sheet = $report->add_worksheet('data_report');

#创建格式

my $title_style = $report->add_format(); $title_style->set_size(11); $title_style->set_bold(); $title_style->set_align('center');

#初始化数据指针

my $sheet_col = 0;

#创建表格

for (my $i=0;$i<=$#cols_name ;$i++) {

$sheet->set_column($cols[$i], length($cols_name[$i])+4);

$sheet->write_unicode($sheet_col,$i,$map->to_unicode($cols_name[$i]),$title_style);

}

$sheet->freeze_panes(1, 0);#冻结行

while (my @row = $sth->fetchrow_array) {

$sheet_col++;

for (my $i=0;$i<=$#cols_name ;$i++) {

next if ($row[$i] eq '');

$sheet->write_unicode($sheet_col,$i,$map->to_unicode($row[$i]));

}

}

warn "all done!!!/n";

#结束

END {

$report->close() if ($report);

$dbh->disconnect();

warn "write to: $ARGV[0]/n";

#生成GB2312编码系统

my $map = Unicode::Map->new("gb2312");

#产生报表

my $report = Spreadsheet::WriteExcel::Big->new("$ARGV[0]") || die "不能生成报表文件:$!";

#创建报表的工作表

my $sheet = $report->add_worksheet('data_report');

#创建格式

my $title_style = $report->add_format(); $title_style->set_size(11); $title_style->set_bold(); $title_style->set_align('center');

#初始化数据指针

my $sheet_col = 0;

#创建表格

for (my $i=0;$i<=$#cols_name ;$i++) {

$sheet->set_column($cols[$i], length($cols_name[$i])+4);

$sheet->write_unicode($sheet_col,$i,$map->to_unicode($cols_name[$i]),$title_style);

}

$sheet->freeze_panes(1, 0);#冻结行

while (my @row = $sth->fetchrow_array) {

$sheet_col++;

for (my $i=0;$i<=$#cols_name ;$i++) {

next if ($row[$i] eq '');

$sheet->write_unicode($sheet_col,$i,$map->to_unicode($row[$i]));

}

}

warn "all done!!!/n";

#结束

END {

$report->close() if ($report);

$dbh->disconnect();

}

 

posted on 2010-04-25 17:19  挽星  阅读(256)  评论(0)    收藏  举报