php开源嘛
首页 | English | MySql数据库 | Php编程 | 建站杂烩 | 系统服务器 | 资源共享 | 专题 | 才桀网 | 支持论坛
  当前位置:主页>MySql数据库>文章内容
从MySQL导出XLS数据库工具
来源:网络 作者:本站整理 发布时间:2007-09-07  

从MySQL导出XLS数据库工具

这个脚本是使用Perl生成excel xls文件的工具。依赖一些模块,你可以在linux下使用,产生xls文件。使用方式是命令行+参数。非常方便。

  #!/usr/bin/perl

  #===============================

  # mysql to excel

  # lastmodify at 2005-1-5

  # copyright by hoowa

  #=============================

  use strict; #严格语法检测

  use DBI; #数据库引擎

  use Unicode::Map; #Unicode引擎

  #use Spreadsheet::WriteExcel; #Excel报表引擎

  use Spreadsheet::WriteExcel::Big; #大文件Excel报表引擎

  my $hostname='192.168.1.133';

  my $username='user';

  my $password='pass';

  my $dbname='db';

  my $trans_compress=1; #任何非一的数关闭数据库到程序间传输压缩

  $|=1;

  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');

  #解析来内容

  if ($#ARGV != '1') {

  print qq~syntax: my2excel.pl <writefilename> "[where expression]"

  ~;

  exit;

  }

  $ARGV[1]=~ s/\"//g;

  warn qq~

  mysql to excel

  by hoowa.sun

  =====================

  sql: $ARGV[1]

  ~;

  my $dbh =

  DBI->connect("DBI:mysql:mysql_compression=$trans_compress;

  database=$dbname;host=$hostname",$username,$password);

  my $sth = $dbh->prepare("$ARGV[1]") || die $dbh->errstr;

  my $rows = $sth->execute() or die $sth->errstr;

  warn "rows: $rows found.\n";

  my @cols_name = @{$sth->{'NAME'}};

  if ($#cols_name > $#cols) {

  print "table $ARGV[1] fields out of allow!!(max num. > ".($#cols+1).")\n";

  exit;

  }

  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();

  }

  


(阅读次数:
上一篇:再谈:PHP入门的学习方法   下一篇:mysql5存储过程编写实践
[收藏] [推荐] [评论(0条)] [返回顶部] [打印本页] [关闭窗口]  
用户名: 新注册) 密码: 匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
 §最新评论
  热点文章
·用于SELECT和WHERE子句的SQL函数
·MySQL索引分析和优化
·MySQL数据库下.frm .MYD .MYI损
·怎么删除MySQL数据库中的重复数
·MySQL数据导入与导出
·MySQL数据库中SQL查询语句精华
·如何优化MySQL数据库性能
·MySQL查询优化之查询优化器
·怎么备份MySQL数据库
·如何导入导出*.sql文件到MySQL数
·MySQL数据导入导出方法与工具介
·MySQL索引分析和优化加速网站访
  相关文章
·mysql5存储过程编写实践
·使用MySQL的23个注意事项^……
·MySQL 如何从表中取出随机数据
·如何使用ODBC接口访问MySQL
·Mysql参数优化之初学MYSQL应知道
·优化MYSQL数据库性能的八个方法
·PHPMyAdmin连接MYSQL的问题:故
·高效安全的sql查询代码如何编写?
·轻松接触MySQL数据库支持的3个引
·SQL删除逻辑重复记录的方法{事例
·MySQL编码问题的经验总结
·MySQL服务器内部安全数据目录访

关于我们 | 本站声明 | 友情连接 | 诚邀加盟 | 网站地图
版权Power by DedeCms   技术支持QQ =>> 罗江游鱼   Jacking  后台登陆
Copyright @ 2007 公司地址:柳州市东环路268号 邮编:545006 电话:15920389818 桂ICP备07006725号