主页/ 电商学院/网站开发/网站制作之PhpExcel数据批量导入导出

网站制作之PhpExcel数据批量导入导出

归类:网站开发
1、所用的框架是Thinktp 框架
2、所用插件PHPExcel
将我们的下载的PHPExcel 放入ThinkPHP\Library\Vendor 中 具体位置看自身实际情况
导入读取excl表格  vendor('PHPExcel.PHPExcelUser');  //引用文件
  $excel=new \PHPExcelUser($file); //打开$fileexcl文件;
  $data=$excel->excelImport(0); // 0代表从第一行开始
导入后通过循环对数据进行处理和保存;
导出数据  $excel=new \PHPExcelUser($FileName);  //这里的$FileName是文件的导出名称;
  $excel->excelExport($data,$title);  //这里$data为数据,$title 为表格的标题;
 
导入导出比较简单,这里整理了一些遇到的问题:
导入时间问题   在导入表格中的时间格式需要转换一下,转换函数如下:
 
 function excelTime($date, $time = false) {
        if(function_exists('GregorianToJD')){
            if (is_numeric( $date )) {
                $jd = GregorianToJD( 1, 1, 1970 );
                $gregorian = JDToGregorian( $jd + intval ( $date ) - 25569 );
                $date = explode( '/', $gregorian );
                $date_str = str_pad( $date [2], 4, '0', STR_PAD_LEFT )
                    ."-". str_pad( $date [0], 2, '0', STR_PAD_LEFT )
                    ."-". str_pad( $date [1], 2, '0', STR_PAD_LEFT )
                    . ($time ? " 00:00:00" : '');
                return $date_str;
            }
        }else{
            $date=$date>25568?$date+1:25569;
            /*There was a bug if Converting date before 1-1-1970 (tstamp 0)*/
            $ofs=(70 * 365 + 17+2) * 86400;
            $date = date("Y-m-d",($date * 86400) - $ofs).($time ? " 00:00:00" : '');
        }
        return $date;
}
这样就能到就是一个标准的时间格式,不然就是一个数字(非时间戳);
 
长数字字符串在表格中被转换成了科学计数法的数字最简单的方法在字符串前面加个空格或者用
$objActSheet->setCellValueExplicit('A1','330602198804224688', PHPExcel_Cell_DataType::TYPE_STRING);
将a1列的定义为字符串
 
Unknown codepage: 10008 PHPExcel_Shared_CodePage::NumberToName(%d) PHPExcel/Shared/CodePage.php 98 break()原因是 NumberToName() 方法中没有 10008 对应的情况处理,所以会抛出“Unknown codepage: 10008”异常。
 

代码截图



找到PHPExcel/Shared/CodePage.php 文件添加
case 10008: return 'MAC';       break;  //在mac苹果系统下面会出现这个问题
 
 
四、下载出来乱码情况一般是缓冲问题
ob_end_clean(); //清除缓冲区,避免乱码
 
vendor('PHPExcel.PHPExcelUser');
$file=.'/cs.xlsx';//这是路径
$excel=new \PHPExcelUser($file);
$data=$excel->excelImport(1);
//excel表导出
ob_end_clean();//清除缓冲区,避免乱码
header("Content-type: text/html; charset=utf-8");
vendor('PHPExcel.PHPExcelUser');
$file='cs.xlsx';
$excel=new \PHPExcelUser($file);
$data=array();//数据二维数组
$title=array();//数据标题一维数组
$excel->excelExport($data,$title);
 
网站声明:以上文章内容为优加的原创文章,如需转载,请注明出处,谢谢合作!
0 喜欢
494 浏览数

优加商学院

APP开发微信小程序开发网站开发
您好,直接联系技术沟通需求
扫码添加我的微信,直谈需求
非工作时间技术回复慢请谅解
咨询更详细需求
提交信息后我们会第一时间与你取得联系,请大致把需求填写在"咨询内容"里。
姓名
手机
咨询内容
立即提交