PHP读取excel

 使用PHPExcel来读取excel文件,以下代码读取出来的文件包含标题栏

注:单元格第一行以1开始,第一列以0开始

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

class ExcelHelper{
	public function importFileContacts($filename){
		try {
                        //解决文件中文名问题
			$filename = iconv("UTF-8","GB2312",$filename);
            if (!file_exists($filename)) {
                return false;
            }
            //chmod($filename, 0750);linux下改变文件权限
            $filetype = $this->getFileType($filename);
            //根据文件类型读取excel文件
            if ($filetype == "xlsx") {
                $objReader = PHPExcel_IOFactory::createReader('Excel2007');
                $objReader->setReadDataOnly(true);
            } elseif ($filetype == "xls") {
                $objReader = PHPExcel_IOFactory::createReader('Excel5');
                $objReader->setReadDataOnly(true);
            } else {
                return false;
            }
            $mems = NULL;
            $objPHPExcel = $objReader->load($filename);
            $objWorksheet = $objPHPExcel->getActiveSheet();
            $highestRow = $objWorksheet->getHighestRow(); // e.g. 10
            $highestColumn = $objWorksheet->getHighestColumn(); // e.g 'F'
            $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn); // e.g. 5
            for ($row = 1; $row <= $highestRow; $row++) {
                for ($col = 0; $col < $highestColumnIndex; $col++) {
                    $mem[$col] = trim($objWorksheet->getCellByColumnAndRow($col, $row)->getValue());
                }
                $mems[$row - 1] = $mem;
            }
            return $mems;
        } catch (Exception $e) {
            echo 'EXCEL ERROR:' . $e->getMessage();
            $errText = "Read excel error:Please retry later!";
            return $errText;
        }
	}
	
	/**
	 * 获取文件类型
	 * @param $filenamePath 文件路径或者文件名
	 */
	private function getFileType($filenamePath){
	    if (!$filenamePath){
	        return false;
	    }
        $filenameArr = explode('/', $filenamePath);
	    $count = count($filenameArr);
	    $filename = $filenameArr[$count-1];
	    
	    $filetypeArr = explode('.', $filename);
	    $count = count($filetypeArr);
	    $filetype = $filetypeArr[$count-1];
	    return $filetype;   
	}
}
 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值