设为首页 收藏本站
查看: 1274|回复: 0

[经验分享] perl写入excel

[复制链接]

尚未签到

发表于 2018-8-30 11:31:38 | 显示全部楼层 |阅读模式
#!/usr/bin/env perl  
use strict;
  
use DBI;
  
use Encode;
  
use OLE::Storage_Lite;
  
use Spreadsheet::WriteExcel::Big;
  

  
#数据库信息
  
my $host = {
  
    user => 'root',
  
    pass => '123456',
  
    host => '127.0.0.1',
  
    database => 'aries_host_info',
  
    port => 3306,
  
    table=>'host',
  
};
  

  
#输出文件格式
  
my ($sec,$min,$hour,$mday,$mon,$year) = (localtime)[0..5];
  
($sec,$min,$hour,$mday,$mon,$year) = (
  
sprintf("%02d", $sec),
  
sprintf("%02d", $min),
  
sprintf("%02d", $hour),
  
sprintf("%02d", $mday),
  
sprintf("%02d", $mon + 1),
  
$year + 1900
  
);
  
my $date="$year$mon$mday$hour$min";
  

  
#输出excel名字  邮件实体附件
  
my $excel_file="${date}.xls";
  

  

  
my @cols=('A:A','B:B','C:C','D:D','E:E','F:F','G:G','H:H','I:I','J:J',
  
'K:K','L:L','M:M','N:N','O:O','P:P','Q:Q','R:R','S:S','T:T','U:U',
  
'V:V','W:W','X:X','Y:Y','Z:Z','AA:A','BB:B','CC:C','DD:D','EE:E',
  
'FF:F','GG:G','HH:H','II:I','JJ:J','KK:K','LL:L','MM:M','NN:N',
  
'OO:O','PP:P','QQ:Q','RR:R','SS:S','TT:T','UU:U','VV:V','WW:W',
  
'XX:X','YY:Y','ZZ:Z');
  

  
#连接数据库
  
my $dbh=DBI->connect("DBI:mysql:$host->{database};host=$host->{host};port=$host->{port}",$host->{user},$host->{pass},{RaiseError=>1});
  

  
#设置字符集
  
$dbh->do ("set character_set_client = 'utf8'");
  
$dbh->do ("set character_set_connection = 'utf8'");
  
$dbh->do ("set character_set_results = 'utf8'");
  

  
#sql 语句
  
my $sql=qq(select * from $host->{table};);
  
my $sth=$dbh->prepare($sql) or die 'Unable to perpare our query:'.$dbh->errstr."\n";
  
my $results=$sth->execute() or die 'Unable to execute our query:'.$dbh->errstr."\n";
  

  
#打印出sql的select行数到桌面、
  
if ($results == 0){
  
    print "查询结果 : N/A";
  
}else{
  
#print "$sql cmd find $results rows.\n";
  
    print "查询结果:$results 行.\n";
  
    }
  

  
#从数据库查询结果的列名
  
my @cols_name = @{$sth->{'NAME'}};
  

  
if ($#cols_name > $#cols)
  
{
  
print "result table fields overflow!(max num. > ".($#cols+1).")\n";
  
exit;
  
}
  
print "正在写入excel...\n";
  

  
#创建excel文件
  
my $excel = Spreadsheet::WriteExcel::Big->new($excel_file) || die "excel 文件创建失败: $!";
  

  
#创建 excel sheet
  
my $sheet = $excel->add_worksheet('anbound');
  

  
#excel文件格式
  
my $title_style = $excel->add_format();
  
$title_style->set_size(11);
  
$title_style->set_bold();
  
$title_style->set_align('center');
  
my $sheet_col = 0;   #列信息
  

  

  
#将结果输出到excel 文件
  
for (my $i=0; $iset_column($cols[$i], length($cols_name[$i])+20);
  
$sheet->write($sheet_col,$i,$cols_name[$i],$title_style);
  
}
  

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

  
while (my @row = $sth->fetchrow_array)
  
{
  
        $sheet_col++;
  
        for (my $i=0; $i< scalar @cols_name ;$i++)
  
        {
  
                next if ($row[$i] eq '');             #无信息,就不写入
  
                Encode::_utf8_on($row[$i]);         #把$row当作utf8来处理
  
                $sheet->write($sheet_col, $i,$row[$i]);
  
        }
  
}
  
print "excel写入完成!\n";



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-558886-1-1.html 上篇帖子: Ubuntu安装CPAN上的扩展包for Perl 下篇帖子: 关于perl中,中文乱码的解决方法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表