ThinkPHPでPHPExcelを呼び出す問題解決策
ThinkPHPでPHPExcelを呼び出すとデータは完全に読めますが、次のD、Mまたはテンプレートを呼び出すときにエラーが発生します.△私一人でこの問題に遭遇したのか分からない.研究の末、やっと解決策を見つけた.皆さんと分かち合いましょう.ほほほ!1,まずPHPExcelのパッケージをダウンロードし,ThinkPHP/Vendor/(つまりThinkのサードパーティクラスライブラリディレクトリ)の下に置く.2、関数を呼び出します.
3、呼び出します.
4、エラーデータ:
本文は“海磊”のブログから出て、転載をお断りします!
- protected function Import_Execl($file){
- if(!file_exists($file)){
- return array("error"=>1);
- }
- Vendor("PHPExcel.PHPExcel");
- $PHPExcel = new PHPExcel();
- $PHPReader = new PHPExcel_Reader_Excel2007();
- if(!$PHPReader->canRead($file)){
- $PHPReader = new PHPExcel_Reader_Excel5();
- if(!$PHPReader->canRead($file)){
- return array("error"=>2);
- }
- }
- $PHPExcel = $PHPReader->load($file);
- $SheetCount = $PHPExcel->getSheetCount();
- for($i=0;$i<$SheetCount;$i++){
- $currentSheet = $PHPExcel->getSheet($i);
- $allColumn = $this->ExcelChange($currentSheet->getHighestColumn());
- $allRow = $currentSheet->getHighestRow();
- $array[$i]["Title"] = $currentSheet->getTitle();
- $array[$i]["Cols"] = $allColumn;
- $array[$i]["Rows"] = $allRow;
- $arr = array();
- for($currentRow = 1 ;$currentRow<=$allRow;$currentRow++){
- $row = array();
- for($currentColumn=0;$currentColumn<$allColumn;$currentColumn++){
- $row[$currentColumn] = $currentSheet->getCellByColumnAndRow($currentColumn,$currentRow)->getValue();
- }
- $arr[$currentRow] = $row;
- }
- $array[$i]["Content"] = $arr;
- }
- spl_autoload_register(array('Think','autoload'));// , ThinkPHP PHPExcel
- unset($currentSheet);
- unset($PHPReader);
- unset($PHPExcel);
- unlink($file);
- return array("error"=>0,"data"=>$array);
- }
-
- protected function ExcelChange($str){// Execl
- $len = strlen($str)-1;
- $num = 0;
- for($i=$len;$i>=0;$i--){
- $num += (ord($str[$i]) - 64)*pow(26,$len-$i);
- }
- return $num;
- }
3、呼び出します.
- public function import(){
- if(isset($_FILES["import"]) && ($_FILES["import"]["error"] == 0)){
- $result = $this->Import_Execl($_FILES["import"]["tmp_name"]);
- if($this->Execl_Error[$result["error"]] == 0){
- $execl_data = $result["data"][0]["Content"];
- unset($execl_data[1]);
- $data = D("Data");
- foreach($execl_data as $k=>$v){
- $d["serial_no"] = $v[0];
- $d["check_no"] = $v[1];
- $d["work_no"] = $v[2];
- $d["class_name"] = $v[3];
- $d["user_name"] = $v[4];
- $d["new_class"] = $v[5];
- $d["error_level"] = $v[6];
- $data->data($d)->add();
- }
- $this->success($this->Execl_Error[$result["error"]]);
- }else{
- $this->error($this->Execl_Error[$result["error"]]);
- }
- }else{
- $this->error(" ");
- }
- }
4、エラーデータ:
- protected $Execl_Error = array(" "," ","Execl ");
本文は“海磊”のブログから出て、転載をお断りします!