×

phpexcel开发文档

phpexcel开发文档(php写excel)

admin admin 发表于2023-04-01 17:28:08 浏览48 评论0

抢沙发发表评论

本文目录一览:

thinkphp3.1中的phpexcel导入怎么用

首先,去PHPExcel官方网站下载PHPExcel,官方地址为;.我下的是1.8.0版本的.解压后发现还是蛮大的,有十几M,不知道其他版本是不是会小点.

这里写图片描述

把解压好的PHPExcel文件放在ThinkPHP的Vender文件夹下(专门放第三方类库的),如下图

这里写图片描述

其次,创建Excel转换数组类,并把它放在ThinkPHP\Extend\Library\ORG\Util目录下

class ExcelToArrary {

public function __construct() {

Vendor("PHPExcel.Classes.PHPExcel");//引入phpexcel类(留意路径,不了解路径可以查看下手册)

Vendor("PHPExcel.Classes.PHPExcel.IOFactory"); //引入phpexcel类(留意路径)

}

public function read($filename,$encode,$file_type){

if(strtolower ( $file_type )=='xls')//判断excel表类型为2003还是2007

{

Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel5"); //引入phpexcel类(留意路径)

$objReader = PHPExcel_IOFactory::createReader('Excel5');

}elseif(strtolower ( $file_type )=='xlsx')

{

Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel2007");//引入phpexcel类(留意路径)

$objReader = PHPExcel_IOFactory::createReader('Excel2007');

}

$objReader-setReadDataOnly(true);

$objPHPExcel = $objReader-load($filename);

$objWorksheet = $objPHPExcel-getActiveSheet();

$highestRow = $objWorksheet-getHighestRow();

$highestColumn = $objWorksheet-getHighestColumn();

$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);

$excelData = array();

for ($row = 1; $row = $highestRow; $row++) {

for ($col = 0; $col $highestColumnIndex; $col++) {

$excelData[$row][] =(string)$objWorksheet-getCellByColumnAndRow($col, $row)-getValue();

}

}

return $excelData;

}

}

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

如右图这里写图片描述

现在来说Excel,表格的结构样式和MySQL样式要类似,表格样式如下(本人对Excel使用只是一般,所以如果有Excel大神做的报表,不知后果如何).

这里写图片描述

前端页面相关代码:

div

form method="post" action="{:U('Index/upload')}" enctype="multipart/form-data"

font导入Excel数据:/font

label for="file_stu"上传/label

input name="file_stu" type="file" id="file_stu" /

h3温馨提示:/h3

p请确认您的Excel表格类型是xls的,以免出现兼容问题./p

inputtypeinputtype="submit" class="sure" value="导入" /

/form

/div

1

2

3

4

5

6

7

8

9

10

1

2

3

4

5

6

7

8

9

10

最后,控制器部分使用了Thinkphp自带的上传类,使用unlink()函数是为了删除上传的excel表格,以免文件夹存入过多文件,调试代码时可先注释掉.或者不写也行,把删除文件的工作交给你们的运维.代码中foreach循环部分$v[]里的0, 1,2可以改动以下看看与Excel表格里的内容是什么关系.可以把数组打印出来看一看,你就很清楚了-phpexcel开发文档

相关代码:

public function upload(){

import('ORG.Util.ExcelToArrary');//导入excelToArray类

if (! empty ( $_FILES ['file_stu'] ['name'] )){

import('ORG.Net.UploadFile');

$upload = new UploadFile();// 实例化上传类

$upload-maxSize = 3145728 ;// 设置附件上传大小

$upload-allowExts = array('xls', 'xlsx');// 设置附件上传类型

$upload-savePath = './Uploads/';// 设置附件上传目录

if(!$upload-upload()) {// 上传错误提示错误信息

$this-error($upload-getErrorMsg());

}else{// 上传成功 获取上传文件信息

$info = $upload-getUploadFileInfo();

}

}else{

$this-error('(⊙o⊙)~没传数据就导入?!你在逗我?!');

}

//dump($info);die;

$ExcelToArrary=new ExcelToArrary();//实例化

$res=$ExcelToArrary-read($info[0]['savepath'].$info[0]['savename'],"UTF-8",$info[0]['extension']);//传参,判断office2007还是office2003-phpexcel开发文档

$res = array_slice($res,1); //为了去掉Excel里的表头,也就是$res数组里的$res[0];

//dump($res);

foreach ( $res as $k = $v ){ //循环excel表

$data[$k]['mobile'] = $v [0];//创建二维数组

$data[$k]['name'] = $v [1];

$data[$k]['duty'] = $v [2];

}

//dump($data);die;

$result=M('appkey')-addAll($data);

if(!$result){

$this-error('导入数据库失败');

exit();

}else{

$filename = './Uploads/'.$info[0]['savename'];//上传文件绝对路径,unlink()删除文件函数

if (unlink($filename)) {

$this-success ( '导入成功' );

}else{

$this-error('缓存删除失败');

}

}

}

phpexcel 支持什么版本的 excel

phpexcel 支持生成Excel(.xls)、Excel2007(.xlsx)文档,此外还支持PDF、HTML、CSV文档的生成。此外,PHPExcel还支持以现有的Excel文档为模板填充数据生成新的以上文档。并且,其本身的API文档和示例demo相当完整,非常有助于开发人员使用。-phpexcel开发文档

当前的版本是1.7.6,下载解压后的PHPExcel的目录结构如下所示:

其中:

Classes目录下是PHPExcel的源代码文件:PHPExcel.php文件是类库的接口,外部的PHP代码通过它来实现对PHPExcel的调用;PHPExcel目录下是各种不同文档(如Excel、Excel2007、PDF等)的读取和生成的具体操作代码,它们由Classes目录下的PHPExcel.php文件通过工厂模式统一进行调用。-phpexcel开发文档

Documentation目录下是PHPExcel的官方帮助文档,尤其是API目录下网页文件全部是PHPExcel的API帮助文档,而其它的则是对这个开源项目的介绍。

Tests目录下是PHPExcel的将近40个示例小程序,可以与Classes目录一同放到Apache+PHP环境下进行测试与学习。

php导出excel表后,打包成压缩包,然后下载到本地如何实现?

用PHPExcel,PHPExcel是相当强大的 MS Office Excel 文档生成类库。

你上它的官/网把程序包下/载下来,里面有 PHPExcel 的程序、还有30个实例程序和三个文档。

看一下其中的开发文档你就会用了。

读取(这段在开发文档里有的,在13页):

require_once '../Classes/PHPExcel/IOFactory.php';

$objReader = PHPExcel_IOFactory::createReader('Excel2007');

$objReader-setReadDataOnly(true);

$objPHPExcel = $objReader-load("test.xlsx");

$objWorksheet = $objPHPExcel-getActiveSheet();

echo 'table' . "\n";

foreach ($objWorksheet-getRowIterator() as $row) {

echo 'tr' . "\n";

$cellIterator = $row-getCellIterator();

$cellIterator-setIterateOnlyExistingCells(false);

foreach ($cellIterator as $cell) {

echo 'td' . $cell-getValue() . '/td' . "\n";

}

echo '/tr' . "\n";

}

echo '/table' . "\n";

?