0

0

ThinkPHP使用PHPExcel实现Excel数据导入导出完整实例,thinkphpphpexcel

php中文网

php中文网

发布时间:2016-06-13 09:29:07

|

1562人浏览过

|

来源于php中文网

原创

ThinkPHP使用PHPExcel实现Excel数据导入导出完整实例,thinkphpphpexcel

本文所述实例是使用在thinkphp的开发框架上,要是使用在其他框架也是同样的方法,很多人可能不能正确的实现excel的导入导出,问题基本上都是phpexcel的核心类引用路径出错造成的,如果有问题大家务必要对路劲是否引用正确进行测试。

具体操作步骤如下:

(一)导入Excel

第一,在前台html页面进行上传文件:如:

导入Excel表:

第二,在对应的php文件进行文件的处理

立即学习PHP免费学习笔记(深入)”;

大米商城damishop
大米商城damishop

damishop介绍 大米外贸商城系统 简称damishop 完全开源版,只需做一种语言一键开启全球133中语言自动翻译功能,价格实现自动汇率转换,集成微信支付宝 paypal以及国外主流支付方式,自带文章博客系统,首创支持可视化编辑。 软件架构 基于MVC+语言包模式,增加控制台,API导入产品方便对接其他系统(带json示例数据)。 使用要求

下载

 if (! empty ( $_FILES ['file_stu'] ['name'] )) 
 {
  $tmp_file = $_FILES ['file_stu'] ['tmp_name'];
  $file_types = explode ( ".", $_FILES ['file_stu'] ['name'] );
  $file_type = $file_types [count ( $file_types ) - 1];
   /*判别是不是.xls文件,判别是不是excel文件*/
   if (strtolower ( $file_type ) != "xls")       
  {
     $this->error ( '不是Excel文件,重新上传' );
   }
  /*设置上传路径*/
   $savePath = SITE_PATH . '/public/upfile/Excel/';
  /*以时间来命名上传的文件*/
   $str = date ( 'Ymdhis' ); 
   $file_name = $str . "." . $file_type;
   /*是否上传成功*/
   if (! copy ( $tmp_file, $savePath . $file_name )) 
   {
     $this->error ( '上传失败' );
   }
  /*
    *对上传的Excel数据进行处理生成编程数据,这个函数会在下面第三步的ExcelToArray类中

   注意:这里调用执行了第三步类里面的read函数,把Excel转化为数组并返回给$res,再进行数据库写入
  */
 $res = Service ( 'ExcelToArray' )->read ( $savePath . $file_name );
  /*
    重要代码 解决Thinkphp M、D方法不能调用的问题  
    如果在thinkphp中遇到M 、D方法失效时就加入下面一句代码
  */
  //spl_autoload_register ( array ('Think', 'autoload' ) );
  /*对生成的数组进行数据库的写入*/
  foreach ( $res as $k => $v ) 
  {
    if ($k != 0) 
   {
      $data ['uid'] = $v [0];
      $data ['password'] = sha1 ( '111111' );
      $data ['email'] = $v [1];
      $data ['uname'] = $v [3];
     $data ['institute'] = $v [4];
     $result = M ( 'user' )->add ( $data );
     if (! $result) 
     {
       $this->error ( '导入数据库失败' );
     }
   }
  }
}

第三:ExcelToArrary类,用来引用phpExcel并处理Excel数据的
此处注意:ExcelToArrary类建在根目录下的 addons /services/ExcelToArrary.class.php中

class ExcelToArrary extends Service{
 public function __construct() {
   /*导入phpExcel核心类  注意 :你的路径跟我不一样就不能直接复制*/
   include_once('./Excel/PHPExcel.php');
 }
/**
* 读取excel $filename 路径文件名 $encode 返回数据的编码 默认为utf8
*以下基本都不要修改
*/ 
public function read($filename,$encode='utf-8'){
     $objReader = PHPExcel_IOFactory::createReader('Excel5'); 
     $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; 
  }   
 }

第四,以上就是导入的全部内容,phpExcel包附在最后。

(二)Excel的导出(相对于导入简单多了)

第一,先查出数据库里面要生成Excel的数据,如:

$data= M('User')->findAll();  //查出数据
$name='Excelfile';  //生成的Excel文件文件名
$res=service('ExcelToArrary')->push($data,$name);

第二,ExcelToArrary类,用来引用phpExcel并处理数据的   

class ExcelToArrary extends Service{
public function __construct() {
   /*导入phpExcel核心类  注意 :你的路径跟我不一样就不能直接复制*/
    include_once('./Excel/PHPExcel.php');
}
/* 导出excel函数*/
public function push($data,$name='Excel'){
 error_reporting(E_ALL);
 date_default_timezone_set('Europe/London');
 $objPHPExcel = new PHPExcel();

/*以下是一些设置 ,什么作者 标题啊之类的*/
 $objPHPExcel->getProperties()->setCreator("转弯的阳光")
     ->setLastModifiedBy("转弯的阳光")
     ->setTitle("数据EXCEL导出")
     ->setSubject("数据EXCEL导出")
     ->setDescription("备份数据")
     ->setKeywords("excel")
    ->setCategory("result file");
 /*以下就是对处理Excel里的数据, 横着取数据,主要是这一步,其他基本都不要改*/
foreach($data as $k => $v){
   $num=$k+1;
   $objPHPExcel->setActiveSheetIndex(0)
  //Excel的第A列,uid是你查出数组的键值,下面以此类推
  ->setCellValue('A'.$num, $v['uid'])  
  ->setCellValue('B'.$num, $v['email'])
  ->setCellValue('C'.$num, $v['password'])
  }
  $objPHPExcel->getActiveSheet()->setTitle('User');
  $objPHPExcel->setActiveSheetIndex(0);
   header('Content-Type: application/vnd.ms-excel');
   header('Content-Disposition: attachment;filename="'.$name.'.xls"');
   header('Cache-Control: max-age=0');
   $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
   $objWriter->save('php://output');
   exit;
}

第三,以上就是导出的全部内容,phpExcel本站下载地址http://www.bkjia.com/codes/194070.html

thinkphp中使用phpexcel导入excel表格,出现PHPExcel_IOFactory没有发现

提示不是说了么,没找到那就是路径不对,在检查下吧
 

thinkphp使用phpexcel通过excel上传数据到数据库报错:

可能是你excel格式不规范
我用的也是tp的框架,操作excel时,没有问题的
 

WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

43

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

35

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

41

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

204

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

9

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

8

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

3

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

2

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号