ホームページ >バックエンド開発 >PHPチュートリアル >PHPExcel が Excel にエクスポートされ、エラーが報告される

PHPExcel が Excel にエクスポートされ、エラーが報告される

WBOY
WBOYオリジナル
2016-06-23 13:30:431372ブラウズ

TP3.2+PHPExcel の使用
エラーページ:

public function outxls() {		$model = D($this->dbname);		$map = $this->_search();		if (method_exists($this, '_filter')) {			$this->_filter($map);		}		$list = $model->where($map)->field('id,status,yewujindu,fenlei,uid,juid,juname,uuid,uuname,xcrq,xingming,phone,type,introduce,introphone,daikuanpro,addtime,uname,addm,updatetime,sex,birth,marry,shenhu,shebaonianshu,shebaojishu,baoxianjiaoe')->select();	    $headArr=array('ID','进展','公司名称','下次联系','联系人','添加人','添加时间','更新时间');	    $filename='客户管理';		$this->xlsout($filename,$headArr,$list);	}

エクスポートされたフィールドが多すぎると思われます。さらに 27 フィールドを追加すると、エラーが報告されます。エクスポートフィールドの制限はどこで変更できますか?


ディスカッションに返信 (解決策)

セル座標が無効です

xlsout メソッドを投稿して見てください。
重要なのは列番号生成部分です

セル座標が無効です

xlsout メソッドを投稿して見てください。
キーは列番号生成部分です


public function xlsout($filename='数据表',$headArr,$list){					//导入PHPExcel类库,因为PHPExcel没有用命名空间,只能inport导入		import("Org.Util.PHPExcel");		import("Org.Util.PHPExcel.Writer.Excel5");		import("Org.Util.PHPExcel.IOFactory.php");		$this->getExcel($filename,$headArr,$list);	}public	function getExcel($fileName,$headArr,$data){		//对数据进行检验		if(empty($data) || !is_array($data)){			die("data must be a array");		}		//检查文件名		if(empty($fileName)){			exit;		}		$date = date("Y_m_d",time());		$fileName .= "_{$date}.xls";		//创建PHPExcel对象,注意,不能少了\		$objPHPExcel = new \PHPExcel();		$objProps = $objPHPExcel->getProperties();					//设置表头		$key = ord("A");		foreach($headArr as $v){			$colum = chr($key);			$objPHPExcel->setActiveSheetIndex(0)->setCellValue($colum.'1', $v);			$key += 1;		}		$column = 2;		$objActSheet = $objPHPExcel->getActiveSheet();		//设置为文本格式		foreach($data as $key => $rows){ //行写入			$span = ord("A");			foreach($rows as $keyName=>$value){// 列写入				$j = chr($span);				$objActSheet->setCellValueExplicit($j.$column, $value);				$span++;			}			$column++;		}		$fileName = iconv("utf-8", "gb2312", $fileName);		//重命名表		// $objPHPExcel->getActiveSheet()->setTitle('test');		//设置活动单指数到第一个表,所以Excel打开这是第一个表		$objPHPExcel->setActiveSheetIndex(0);		ob_end_clean();//清除缓冲区,避免乱码		header('Content-Type: application/vnd.ms-excel');		header("Content-Disposition: attachment;filename=\"$fileName\"");		header('Cache-Control: max-age=0');		$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');		$objWriter->save('php://output'); //文件通过浏览器下载		exit;	}

           $span = ord("A");            foreach($rows as $keyName=>$value){// 列写入                $j = chr($span);                 $objActSheet->setCellValueExplicit($j.$column, $value);                $span++;            }

これは間違っています!
$span = ord('Z')+1 の場合、chr(($span) は [
明らかに間違っています。正しいものは AA であるはずです
したがって、
function CellName($n) {  $r = '';  do {    $m = $n % 26;    $n = intval($n / 26);    $r = chr(65 + $m - ($r ? 1 : 0)) . $r;  }while($n > 0);  return $r;}
を計算するにはそのような関数が必要です
幸いなことに、php はまた、 C 言語のいくつかの機能を保持しており、この計算を簡単に行うことができます
$c = 'A';for($i=0; $i<100; $i++) printf("%s %s\n", $i, $c++);


この機能を使用すると、プログラムは
           $span = "A";            foreach($rows as $keyName=>$value){// 列写入                $j = $span;                 $objActSheet->setCellValueExplicit($j.$column, $value);                $span++;            }

           $span = ord("A");            foreach($rows as $keyName=>$value){// 列写入                $j = chr($span);                 $objActSheet->setCellValueExplicit($j.$column, $value);                $span++;            }

のように書くことができます。 これは間違いです
$span = ord('Z') の場合 +1 の場合、 chr(($span) は [
を取得します。これは明らかに間違っています。正しいものは AA であるはずです
したがって、
function CellName($n) {  $r = '';  do {    $m = $n % 26;    $n = intval($n / 26);    $r = chr(65 + $m - ($r ? 1 : 0)) . $r;  }while($n > 0);  return $r;}
を計算するにはそのような関数が必要です
幸いなことに、php には C 言語のいくつかの機能も保持されており、非常に簡単に使用できます。この計算をしてください
$c = 'A';for($i=0; $i<100; $i++) printf("%s %s\n", $i, $c++);


この機能を使用すると、プログラムは
           $span = "A";            foreach($rows as $keyName=>$value){// 列写入                $j = $span;                 $objActSheet->setCellValueExplicit($j.$column, $value);                $span++;            }
として書くことができます


アドバイスありがとうございます
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。