thinkphp之Excel的导入

2016-03-22更新: 在github上传了一个demo,对导出进行了封装,只需调用thinkPHP的function中的importExcel函数就可以啦,thinkPHP3.2实现excel导入

1.导入phpexcel类库(见上篇thinkphp之Excel的导出

2.定义Excel转换数组类,路径和代码如下:


ExcelToArrary代码:

<?php
class ExcelToArrary {
  public function __construct() {
		Vendor('PHPExcel.PHPExcel');
	    Vendor('PHPExcel.PHPExcel.IOFactory');
	    Vendor('PHPExcel.PHPExcel.Reader.Excel5');
		vendor('phpExcel.PHPExcel.Reader.Excel2007');	
  }
  public function read($filename,$encode,$file_type){
	        if(strtolower ( $file_type )=='xls')//判断excel表类型为2003还是2007
			{
				Vendor("Excel.PHPExcel.Reader.Excel5"); 
				$objReader = PHPExcel_IOFactory::createReader('Excel5');
			}elseif(strtolower ( $file_type )=='xlsx')
			{
				Vendor("Excel.PHPExcel.Reader.Excel2007"); 
				$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;
	  }
}

3.前端代码:

	<div class="main">
		<p class="currentPosition"><a href="#">号码管理</a>>本地导入号码</p>
		<form method="post" action="<{:U('Excel/add',array('name'=>$vo['managername']),'')}>" enctype="multipart/form-data">
			<input style="width:65px;height:25px" type="file" name="file_stu" />
			<input type="submit" style="background:#438EB9;color:white" value="导入" />
		</form>
		<div>
		
			<div >
			<table>
				<thead>
					<tr>
					<th style="border:1px solid #DDD" > 序号</th>
					<th style="border:1px solid #DDD" > 导入日期</th>
					<th style="border:1px solid #DDD" > 导入文件名</th>
					<th style="border:1px solid #DDD" > 姓名</th>
					<th style="border:1px solid #DDD" > 电话号码</th>
					</tr>
				</thead>
				<tbody>
					<volist name="data"  id="vo">
					    <tr>
							<td style="border:1px solid #DDD" ><{$vo.account}></td>
							<td style="border:1px solid #DDD"><{$vo.datetime}></td>
							<td style="border:1px solid #DDD" ><{$vo.filename}></td>
							<td style="border:1px solid #DDD" ><{$vo.clientname}></td>
							<td style="border:1px solid #DDD" ><{$vo.phone}></td>
						 </tr>
					</volist>
					<tr><td colspan='15'>总用户数:<{$show}><td></tr>
				</tbody>
			</table>
			</div>
		</div>
	</div>

4.控制层代码:

<?php
class ExcelAction extends Action {
	public function __construct()
	{
		parent::__construct();
		import('ORG.Util.ExcelToArrary');//导入excelToArray类
	}
	
	public function index()
	{
		$this->display();
	}
	public function add()
	{	
		$name=session('username');
		$managername=M('manageruser')->where(array('account'=>$name))->find();
		$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 ) != "xlsx" && strtolower ( $file_type ) != "xls")              
		 {
			  $this->error ( '不是Excel文件,重新上传' );
		 }
	
		 /*设置上传路径*/
		 $savePath='Public/admin/Excel/'; //上传路径 
		//检查是否有该文件夹,如果没有就创建,并给予最高权限 
		if(!file_exists($path)) 
		{ 
			mkdir($savePath, 0700); 
		}//END IF
	//	 $savePath = C('UPLOAD_DIR');
	
		 /*以时间来命名上传的文件*/
		 $str = date ( 'Ymdhis' ); 
		 $file_name = $str . "." . $file_type;
		 /*是否上传成功*/
		 if (! copy ( $tmp_file, $savePath . $file_name )) 
		  {
			  $this->error ( '上传失败' );
		  }
		$ExcelToArrary=new ExcelToArrary();//实例化
		$res=$ExcelToArrary->read($savePath.$file_name,"UTF-8",$file_type);//传参,判断office2007还是office2003

		foreach ( $res as $k => $v ) //循环excel表
		  {
			   $k=$k-1;//addAll方法要求数组必须有0索引
			   $data[$k]['clientname'] = $v [1];//创建二维数组		   
			   $data[$k]['phone'] = $v [2];
			   $data[$k]['datetime'] = date('Y-m-d',time());//创建二维数组
			   $data[$k]['managername'] = $managername['managername'];//创建二维数组
			   $data[$k]['filename'] =  $file_types[0];
		  }
		  $kucun=M('salerleadin');//M方法
		  $result=$kucun->addAll($data);
		  if(! $result)
		  {
			  $this->error('导入数据库失败');
			  exit();
		  }
		  else
		  {
			  $this->success ( '导入成功' );	
		  }
	}
}

参考例程:http://blog.csdn.net/sui13725202/article/details/9285501


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值