PHPExcel の Excel ファイルの読み取りに関する問題

WBOY
リリース: 2016-06-20 12:30:27
オリジナル
1556 人が閲覧しました

読み出しコードは以下の通りです。

$uploadfile=$_FILES["file"]['tmp_name'];		if(is_uploaded_file($uploadfile) && $_POST['aid']){			Vendor('PhpExcel.PHPExcel');			Vendor('PHPExcel.IOFactory');			Vendor('PHPExcel.Reader.Excel5');			$objReader = PHPExcel_IOFactory::createReader('Excel5');//use excel2007 for 2007 format			$objPHPExcel = $objReader->load($uploadfile);			$sheet = $objPHPExcel->getSheet(0);			$highestRow = 0; // 取得总行数			$highestColumn = $sheet->getHighestColumn(); // 取得总列数			$start=1;//从哪一行开始录入/删除			if($_POST['diyihang']){				//忽略第一行				$highestRow = $sheet->getHighestRow(); // 取得总行数				$start=2;			}else{				$highestRow= ($sheet->getHighestRow()); // 取得总行数			}			$update=array();			$delete=array();			//获取信息字段			$fresult=M("form")->where("aid = %d",$_POST['aid'])->order("sort")->select();			for($start;$start<=$highestRow;$start++){ 		     	//读取单元格		  		$temp['title']=$objPHPExcel->getActiveSheet()->getCell("B".$start)->getValue();		  						//物业编号,认证码为空 不要				if(empty($temp['title'])){					continue;				}				$temp['assess']=$objPHPExcel->getActiveSheet()->getCell("C".$start)->getValue();		  		$temp['is_status']=$objPHPExcel->getActiveSheet()->getCell("D".$start)->getValue();		  		$temp['sort']=$objPHPExcel->getActiveSheet()->getCell("E".$start)->getValue();		  		$temp['aid']=$_POST['aid'];		  		$coll=ord("F");		  		foreach($fresult as $key=>$one){		  			$temp['form_content'][$one['id']]=$objPHPExcel->getActiveSheet()->getCell(chr($coll).$start)->getValue();		  			$coll++;		  		}		  		$temp['form_content']=serialize($temp['form_content']);		  		if($objPHPExcel->getActiveSheet()->getCell("A".$start)->getValue()){		  			$temp['id']=$objPHPExcel->getActiveSheet()->getCell("A".$start)->getValue();		  			array_push($delete, $temp);		  		}else{		  			array_push($update, $temp);		  		}								unset($temp);							}
ログイン後にコピー

ここでなぜ良いのか悪いのか分かりません。 良い場合は配列データが正常に出力されます。出力データは次のとおりです。
array(2) { [0]=> array(6) { ["title"]=> object(PHPExcel_RichText)#223 (1) { ["_richTextElements":"PHPExcel_RichText":private]=> array(2) { [0]=> object(PHPExcel_RichText_Run)#224 (2) { ["_font":"PHPExcel_RichText_Run":private]=> object(PHPExcel_Style_Font)#227 (12) { ["_name":protected]=> string(6) "瀹嬩綋" ["_size":protected]=> int(11) ["_bold":protected]=> bool(false) ["_italic":protected]=> bool(false) ["_superScript":protected]=> bool(false) ["_subScript":protected]=> bool(false) ["_underline":protected]=> string(4) "none" ["_strikethrough":protected]=> bool(false) ["_color":protected]=> object(PHPExcel_Style_Color)#228 (4) { ["_argb":protected]=> string(8) "FF000000" ["_parentPropertyName":protected]=> NULL ["_isSupervisor":protected]=> bool(false) ["_parent":protected]=> NULL } ["_isSupervisor":protected]=> bool(false) ["_parent":protected]=> NULL ["colorIndex"]=> int(8) } ["_text":"PHPExcel_RichText_TextElement":private]=> string(6) "椤烘櫙" } [1]=> object(PHPExcel_RichText_Run)#225 (2) { ["_font":"PHPExcel_RichText_Run":private]=> object(PHPExcel_Style_Font)#230 (12) { ["_name":protected]=> string(7) "Calibri" ["_size":protected]=> int(11) ["_bold":protected]=> bool(false) ["_italic":protected]=> bool(false) ["_superScript":protected]=> bool(false) ["_subScript":protected]=> bool(false) ["_underline":protected]=> string(4) "none" ["_strikethrough":protected]=> bool(false) ["_color":protected]=> object(PHPExcel_Style_Color)#231 (4) { ["_argb":protected]=> string(8) "FF000000" ["_parentPropertyName":protected]=> NULL ["_isSupervisor":protected]=> bool(false) ["_parent":protected]=> NULL } ["_isSupervisor":protected]=> bool(false) ["_parent":protected]=> NULL ["colorIndex"]=> int(8) } ["_text":"PHPExcel_RichText_TextElement":private]=> string(5) "1-502" } } } ["assess"]=> string(6) "宸蹭氦" ["is_status"]=> float(1) ["sort"]=> float(1000) ["aid"]=> string(3) "692" ["form_content"]=> string(32) "a:2:{i:829;d:123;i:830;d:42225;}" } [1]=> array(6) { ["title"]=> object(PHPExcel_RichText)#236 (1) { ["_richTextElements":"PHPExcel_RichText":private]=> array(2) { [0]=> object(PHPExcel_RichText_Run)#237 (2) { ["_font":"PHPExcel_RichText_Run":private]=> object(PHPExcel_Style_Font)#240 (12) { ["_name":protected]=> string(6) "瀹嬩綋" ["_size":protected]=> int(11) ["_bold":protected]=> bool(false) ["_italic":protected]=> bool(false) ["_superScript":protected]=> bool(false) ["_subScript":protected]=> bool(false) ["_underline":protected]=> string(4) "none" ["_strikethrough":protected]=> bool(false) ["_color":protected]=> object(PHPExcel_Style_Color)#241 (4) { ["_argb":protected]=> string(8) "FF000000" ["_parentPropertyName":protected]=> NULL ["_isSupervisor":protected]=> bool(false) ["_parent":protected]=> NULL } ["_isSupervisor":protected]=> bool(false) ["_parent":protected]=> NULL ["colorIndex"]=> int(8) } ["_text":"PHPExcel_RichText_TextElement":private]=> string(6) "椤烘櫙" } [1]=> object(PHPExcel_RichText_Run)#238 (2) { ["_font":"PHPExcel_RichText_Run":private]=> object(PHPExcel_Style_Font)#243 (12) { ["_name":protected]=> string(7) "Calibri" ["_size":protected]=> int(11) ["_bold":protected]=> bool(false) ["_italic":protected]=> bool(false) ["_superScript":protected]=> bool(false) ["_subScript":protected]=> bool(false) ["_underline":protected]=> string(4) "none" ["_strikethrough":protected]=> bool(false) ["_color":protected]=> object(PHPExcel_Style_Color)#244 (4) { ["_argb":protected]=> string(8) "FF000000" ["_parentPropertyName":protected]=> NULL ["_isSupervisor":protected]=> bool(false) ["_parent":protected]=> NULL } ["_isSupervisor":protected]=> bool(false) ["_parent":protected]=> NULL ["colorIndex"]=> int(8) } ["_text":"PHPExcel_RichText_TextElement":private]=> string(5) "1-503" } } } ["assess"]=> string(6) "鏈浜" ["is_status"]=> float(1) ["sort"]=> float(1001) ["aid"]=> string(3) "692" ["form_content"]=> string(32) "a:2:{i:829;d:125;i:830;d:42225;}" } } 
ログイン後にコピー


なぜ上記のデータ形式が出力されるのか、なぜスタイルがあるのか​​知りたいです


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

誰か答えてくれる人はいますか?

問題が完全に説明されていません。良い時と悪い時は何ですか?同じファイルをアップロードするだけですか、それとも別のファイルをアップロードしますか?さまざまなファイルを比較する形式はありますか? xlsまたはxlsx?同じフォーマットに正常なファイルと不良なファイルがあります。ファイルを開いて内容を比較しましたか?

問題が十分に説明されていません。良い時と悪い時は何ですか?同じファイルをアップロードするだけですか、それとも別のファイルをアップロードしますか?さまざまなファイルを比較する形式はありますか? xlsまたはxlsx?同じフォーマットに正常なファイルと不良なファイルがあります。ファイルを開いて内容を比較しましたか?



ファイル形式は同じファイルの場合もあれば、内容を変更するとインポートできない場合もあります。確かにファイルの中身は違いますが、全て正しいデータです。ファイルの形式も正しいです。

問題は解決されました。型を強制的に変換するだけです (文字列)

//ループして各セルの内容を読み取ります。行は 1 から始まり、列は A から始まることに注意してください。
for($rowIndex=1;$rowIndex<=$allRow;$rowIndex++){ $colIndex++){
$addr = $colIndex.$rowIndex ;
$cell = $currentSheet->getCell($addr)->getValue();
if($cell instanceof PHPExcel_RichText) //Fu テキスト変換文字列
$ cell = $ cell-& gt; __tostring ();

エコー $ セル;

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!