PHP实现导出excel数据的类库用法示例

5年以前  |  阅读数:460 次  |  编程语言:PHP 

本文实例讲述了PHP实现导出excel数据的类库用法。分享给大家供大家参考,具体如下:

今天一个项目要做一个PHP导出数据用excel保存,在网上找到一个本来是想用phpexcel的,后来发现太难了,就换了一个但导出的歌声是XML

类写的很简单,但很实用。只能简单的导出字符串和数字二种格式。

如果你有兴趣,你可以拿去扩充了,基本够用。


    class Excel_XML
    {
    //定于私有变量,顶部标签
    private $header = "<?xml version=\"1.0\" encoding=\"%s\"?\>\n<Workbook xmlns=\"urn:schemas-microsoft-com:
    office:spreadsheet\" xmlns:x=\"urn:schemas-microsoft-com:office:excel\" xmlns:ss=\"urn:schemas-microsoft-com:
    office:spreadsheet\" xmlns:html=\"http://www.w3.org/TR/REC-html40\">";
    //底部标签
    private $footer = "</Workbook>";
    //定于行数组
    private $lines = array();
    //设置编码
    private $sEncoding;
    //设置类型
    private $bConvertTypes;
    //设置sheet名称
    private $sWorksheetTitle;
    //构造函数
    public function __construct(
     $sEncoding = 'UTF-8',$bConvertTypes = false,$sWorksheetTitle = 'Table1')
    {
    $this->bConvertTypes = $bConvertTypes;
    $this->setEncoding($sEncoding);
    $this->setWorksheetTitle($sWorksheetTitle);
    }
    //设置编码,在构造函数里面默认的事UTF-8格式
    public function setEncoding($sEncoding)
    {
    $this->sEncoding = $sEncoding;
    }
    //设置excel的头
    public function setWorksheetTitle ($title)
    {
    $title = preg_replace ("/[\\\|:|\/|\?|\*|\[|\]]/", "", $title);
    $title = substr ($title, 0, 31);
    $this->sWorksheetTitle = $title;
    }
    //增加行函数(关键函数)
    private function addRow ($array)
    {
    $cells = ""; //设置每个单元为空
    foreach ($array as $k => $v)
    {
     $type = 'String'; //默认类型是字符串
     if ($this->bConvertTypes === true && is_numeric($v)): //判断类型
     { $type = 'Number'; }
     $v = htmlentities($v, ENT_COMPAT, $this->sEncoding);
     $cells .= "<Cell><Data ss:Type=\"$type\">" . $v . "</Data></Cell>\n";
    }
     $this->lines[] = "<Row>\n" . $cells . "</Row>\n"; //写入数组
    }
    //增加数组
    public function addArray ($array)
    {
    foreach ($array as $k => $v)
     {$this->addRow ($v);}
    }
    //导出xml
    public function generateXML ($filename = 'excel-export')
    {
    $filename = preg_replace('/[^aA-zZ0-9\_\-]/', '', $filename);
    header("Content-Type: application/vnd.ms-excel; charset=" . $this->sEncoding);
    header("Content-Disposition: inline; filename=\"" . $filename . ".xls\"");
    echo stripslashes (sprintf($this->header, $this->sEncoding));
    echo "\n<Worksheet ss:Name=\"" . $this->sWorksheetTitle . "\">\n<Table>\n";
    foreach ($this->lines as $line)
    echo $line;
    echo "</Table>\n</Worksheet>\n";
    echo $this->footer;
    }
    }

原理很简单,就是把数据数组,读出来,再用XML的标签封上,在用php自带的header()函数告诉游览器,就可以了。

调用:


    public function import()
    {
     $data = array(
     1 => array ('学校名称',"队伍名称")
     );
     foreach($this->team as $key=>$value)
     {
      array_push($data,array($key, $value));
     }
     $xls = new Excel_XML('UTF-8', false, 'My Test Sheet'); //实例化函数
     $xls->addArray($data);
     $xls->generateXML('school'); //导出并设置名称
    }

上面是的写一个导出方式。在游览器运行就已经导出数组$this->team 里面的键和值了。

更多关于PHP相关内容感兴趣的读者可查看本站专题:《php操作office文档技巧总结(包括word,excel,access,ppt)》、《PHP数组(Array)操作技巧大全》、《php排序算法总结》、《PHP常用遍历算法与技巧总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》、《PHP数学运算技巧总结》、《php正则表达式用法总结》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总

希望本文所述对大家PHP程序设计有所帮助。

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例