PHP实现导出excel数据的类库用法示例
网络编程 2021-07-05 08:23www.168986.cn编程入门
这篇文章主要介绍了PHP实现导出excel数据的类库用法,结合实例形式分析了php操作Excel数据的读取与导出操作相关实现技巧,需要的朋友可以参考下
本文实例讲述了PHP实现导出excel数据的类库用法。分享给大家供大家参考,具体如下
今天一个项目要做一个PHP导出数据用excel保存,在网上找到一个本来是想用phpexcel的,后来发现太难了,就换了一个但导出的歌声是XML
类写的很简单,但很实用。只能简单的导出字符串和数字二种格式。
如果你有兴趣,你可以拿去扩充了,基本够用。
class Excel_XML { //定于私有变量,顶部标签 private $header = "<?xml version=\"1.0\" encoding=\"%s\"?\>\n<Workbook xmlns=\"urn:schemas-microsoft-: office:spreadsheet\" xmlns:x=\"urn:schemas-microsoft-:office:excel\" xmlns:ss=\"urn:schemas-microsoft-: office:spreadsheet\" xmlns:html=\"http://.w3./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程序设计有所帮助。
上一篇:Thinkphp连表查询及数据导出方法示例
下一篇:PHP数组操作简单案例分析
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程