ホームページ
バックエンド開発
PHPチュートリアル
PHP で ExcelFileParser を使用して Excel を処理してデータを取得する (バッチでデータベースにインポート可能)_PHP チュートリアル



PHP で ExcelFileParser を使用して Excel を処理してデータを取得する (バッチでデータベースにインポート可能)_PHP チュートリアル
Jul 21, 2016 pm 03:35 PM
excel
php
コード
使用
対処する
コピー
輸入
バッチ
データ
データベース
得る
コードをコピーします コードは次のとおりです:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR /xhtml1/DTD /xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv=" Content-Type" content="text/html" />
<title>Excel データ取得のデモ</title>
<meta name="Keywords" content="TODO" />
<メタ名="説明" コンテンツ="TODO"/>
<div>
<div> ;
<フォームメソッド="POST" アクション="/Index/parse" enctype="multipart/form-data">
<input type="file" name="excel" value="" />
<input type="submit" name="submit" value="Submit" />
</div>
</body> html>
コードをコピー
<?php /*** CopyRight (c) 2009, * All Rights Reserved.
* ファイル名: * 概要:
*
* @author Monday [url=mailto:ixqbar@hotmail.com]ixqbar@hotmail.com[/url ]
* @バージョン
*/
public function parse()
{
/**
* $_FILES 配列の説明
* array(n) {
* ["フォームファイルボックス名"] => array(5) {
* ["name"] => ファイル名を送信
* ["type" ] = > ファイルの種類 Excel を「application/vnd.ms-excel」として送信します
* ["tmp_name"] => 一時ファイル名
* ["error"] => エラー (0 成功 1 ファイルが大きすぎます) Upload_max_filesize2 ファイル大きすぎて MAX_FILE3 を超えています アップロードが不完全 4 ファイルがアップロードされていません)
* ["size"] => ファイルサイズ (単位: KB)
* }
* }
*/
$return =array(0,'');
/**
* 送信するかどうかを決定します
* is_uploaded_file (ファイル名) は、不正な送信を防ぐために、指定されたファイルが POST メソッドを使用してアップロードされるかどうかを決定するために使用されます。通常は、アップロードされたファイルを指定されたパスに保存するために move_upload_file と一緒に使用されます。*/
if(!isset($_FILES) || !is_uploaded_file($_FILES['excel']['tmp_name']) )
{
$ return=array(1,'提出は不正です');
}
//処理中
if(0 == $return[0])
{
import('@.Util.ExcelParser');
$excel=new ExcelParser($_FILES['excel']['tmp_name']);
$return=$excel->main();
//出力処理
print_r($return); >
コードをコピーします
コードは次のとおりです:
<?php
/**
* CopyRight (c) 2009,
* All Rights Reserved.
* ファイル名: Excel データ取得
* 概要:
*
* @author Monday [url=mailto:ixqbar@hotmail.com]ixqbar@hotmail.com [ /url]
* @バージョン 0.1
*/
class ExcelParser
{
private $_excel_handle;
/* *
* コンストラクター
* @param <string> $filename アップロードされたファイルの一時ファイル名
*/
パブリック関数 __construct($filename)
{
/**
* Excelparser クラスを導入します
* 一般的なメソッドは
* には path.'excelparser.php' が必要です
;*/
import('@.Util.PHPExcelParser.excelparser','','.php'); ->excel_handle=new ExcelFileParser();
//
$this->checkErrors($filename) の取得エラー
}
/**
* エラーチェック中
*/
プライベート関数 checkErrors($filename)
/ **
* 方法 1
*/
$error_code=$this->excel_handle->ParseFromFile($filename)
/**
* 方法二
* $file_handle = fopen($this->_filename,'rb');
* $content = fread($file_handle,filesize($this->_filename));
* fclose($file_handle);
* $error_code = $this->_excel->ParseFromString($content);
* unset($content,$file_handle);
*/
switch($error_code)
{
case 0:
//エラーは処理されません
break;
ケース 1:
$this->_data=array(1,'ファイル読み取りエラー (Linux は読み取りおよび書き込み権限に注意)');
ケース 2:
$ this->_data=array(1,'ファイルが小さすぎます');
break;
$this->_data=array(1,'Excel ヘッダーの読み取りに失敗しました'); 4:
$this->_data=array(1,'ファイル読み取りエラー');
case 5:
$this->_data=array(1,'ファイルが空である可能性があります'); ;
ケース 6:
$this->_data=array(1,'不完全なファイル');
ケース 7:
$this->_data=array(1,'データの読み取りエラー');ブレーク;
ケース 8:
$this->_data=array(1,'間違ったバージョン');
}
unset($error_code)
/**
* Excel情報取得
*/
プライベート関数getExcelInfo()
{
if(1==$this->_data[0])return;
/**
* シート数を取得します
* シート単位に対応する行と列を取得します
*/
$this->_excel['sheet_number']=count($this - >_excel_handle->worksheet['name']);
for($i=0;$i<$this->_excel['sheet_number'];$i++)
{
/**
* 行と列
* 注: カウントは 0 から始まります
* /
$row=$this->_excel_handle->worksheet['data'][$i]['max_row'];
$col=$this->_excel_handle->worksheet['data'] $i]['max_col'];
$this->_excel['row_number'][$i]=($row==NULL)?0:++$row[ ' Col_number'][$i]=($col==NULL)?0:++$col;
unset($row,$col)
}
}
/**
* 中国語処理関数
* @return
*/
プライベート関数 uc2html ($str)
{
$ret = '';
for( $i=0; $i<strlen($str)/2; $i++ )
{
$charcode = ord($str[$i* 2 ])+256*ord($str[$i*2+1]);
$ret .= ''.$charcode.';'
}
return mb_convert_encoding($ret,'UTF-8 ') ,'HTML-ENTITIES');
}
/**
* Excelデータ取得
*/
private function getExcelData()
{
if(1==$this->_data[0])return;
//マークを変更
$this->_data[0]=1;
//データを取得
for($i=0;$i<$this->_excel['sheet_number'];$i++)
{
/* *
* 交互行ループ
*/
for($j=0;$j_excel['row_number'][$i];$j++)
{
/**
* 列ループ
*/
for( $ k=0;$k<$this->_excel['col_number'][$i];$k++)
{
/**
* array(4) {
* ["type"] => 型 [0 文字型 1 整数 2 浮動小数点数 3 日付]
* ["font"] => フォント
* ["data"] = > データ
* ...
* }
*/
$data=$this->_excel_handle-> ; worksheet['data'][$i]['cell'][$j][$k];
switch($data['type'])
{
case 0:
//文字型
if( $ this->_excel_handle->sst['unicode'][$data['data']])
{
//中国語処理
$data['data'] = $this->uc2html($this - >_excel_handle->sst['data'][$data['data']]);
}
else
{
$data['data'] = $this->_excel_handle->sst[ ' data'][$data['data']];
break;
ケース 1:
//整数
//TODO
break;
//浮動小数点
//TODO
break;ケース 3:
//Date
//TODO
break;
$this->_data[1][$i][$j][$k]=$data['data']; $data);
}
}
}
}
/**
* メイン関数
* @return <array> array(識別子, 内容)
*/
public function main()
{
//Excel 情報を取得する
$this->getExcelInfo();取得
$this->getExcelData();
return $this->_data
}
;
*
* @author Monday [url=mailto:ixqbar@hotmail.com]ixqbar@hotmail.com[/url ]
* @バージョン
*/
public function parse()
{
/**
* $_FILES 配列の説明
* array(n) {
* ["フォームファイルボックス名"] => array(5) {
* ["name"] => ファイル名を送信
* ["type" ] = > ファイルの種類 Excel を「application/vnd.ms-excel」として送信します
* ["tmp_name"] => 一時ファイル名
* ["error"] => エラー (0 成功 1 ファイルが大きすぎます) Upload_max_filesize2 ファイル大きすぎて MAX_FILE3 を超えています アップロードが不完全 4 ファイルがアップロードされていません)
* ["size"] => ファイルサイズ (単位: KB)
* }
* }
*/
$return =array(0,'');
/**
* 送信するかどうかを決定します
* is_uploaded_file (ファイル名) は、不正な送信を防ぐために、指定されたファイルが POST メソッドを使用してアップロードされるかどうかを決定するために使用されます。通常は、アップロードされたファイルを指定されたパスに保存するために move_upload_file と一緒に使用されます。*/
if(!isset($_FILES) || !is_uploaded_file($_FILES['excel']['tmp_name']) )
{
$ return=array(1,'提出は不正です');
}
//処理中
if(0 == $return[0])
{
import('@.Util.ExcelParser');
$excel=new ExcelParser($_FILES['excel']['tmp_name']);
$return=$excel->main();
//出力処理
print_r($return); >
コードをコピーします
コードは次のとおりです:
<?php
/**
* CopyRight (c) 2009,
* All Rights Reserved.
* ファイル名: Excel データ取得
* 概要:
*
* @author Monday [url=mailto:ixqbar@hotmail.com]ixqbar@hotmail.com [ /url]
* @バージョン 0.1
*/
class ExcelParser
{
private $_excel_handle;
/* *
* コンストラクター
* @param <string> $filename アップロードされたファイルの一時ファイル名
*/
パブリック関数 __construct($filename)
{
/**
* Excelparser クラスを導入します
* 一般的なメソッドは
* には path.'excelparser.php' が必要です
;*/
import('@.Util.PHPExcelParser.excelparser','','.php'); ->excel_handle=new ExcelFileParser();
//
$this->checkErrors($filename) の取得エラー
}
/**
* エラーチェック中
*/
プライベート関数 checkErrors($filename)
/ **
* 方法 1
*/
$error_code=$this->excel_handle->ParseFromFile($filename)
/**
* 方法二
* $file_handle = fopen($this->_filename,'rb');
* $content = fread($file_handle,filesize($this->_filename));
* fclose($file_handle);
* $error_code = $this->_excel->ParseFromString($content);
* unset($content,$file_handle);
*/
switch($error_code)
{
case 0:
//エラーは処理されません
break;
ケース 1:
$this->_data=array(1,'ファイル読み取りエラー (Linux は読み取りおよび書き込み権限に注意)');
ケース 2:
$ this->_data=array(1,'ファイルが小さすぎます');
break;
$this->_data=array(1,'Excel ヘッダーの読み取りに失敗しました'); 4:
$this->_data=array(1,'ファイル読み取りエラー');
case 5:
$this->_data=array(1,'ファイルが空である可能性があります'); ;
ケース 6:
$this->_data=array(1,'不完全なファイル');
ケース 7:
$this->_data=array(1,'データの読み取りエラー');ブレーク;
ケース 8:
$this->_data=array(1,'間違ったバージョン');
}
unset($error_code)
/**
* Excel情報取得
*/
プライベート関数getExcelInfo()
{
if(1==$this->_data[0])return;
/**
* シート数を取得します
* シート単位に対応する行と列を取得します
*/
$this->_excel['sheet_number']=count($this - >_excel_handle->worksheet['name']);
for($i=0;$i<$this->_excel['sheet_number'];$i++)
{
/**
* 行と列
* 注: カウントは 0 から始まります
* /
$row=$this->_excel_handle->worksheet['data'][$i]['max_row'];
$col=$this->_excel_handle->worksheet['data'] $i]['max_col'];
$this->_excel['row_number'][$i]=($row==NULL)?0:++$row[ ' Col_number'][$i]=($col==NULL)?0:++$col;
unset($row,$col)
}
}
/**
* 中国語処理関数
* @return
*/
プライベート関数 uc2html ($str)
{
$ret = '';
for( $i=0; $i<strlen($str)/2; $i++ )
{
$charcode = ord($str[$i* 2 ])+256*ord($str[$i*2+1]);
$ret .= ''.$charcode.';'
}
return mb_convert_encoding($ret,'UTF-8 ') ,'HTML-ENTITIES');
}
/**
* Excelデータ取得
*/
private function getExcelData()
{
if(1==$this->_data[0])return;
//マークを変更
$this->_data[0]=1;
//データを取得
for($i=0;$i<$this->_excel['sheet_number'];$i++)
{
/* *
* 交互行ループ
*/
for($j=0;$j_excel['row_number'][$i];$j++)
{
/**
* 列ループ
*/
for( $ k=0;$k<$this->_excel['col_number'][$i];$k++)
{
/**
* array(4) {
* ["type"] => 型 [0 文字型 1 整数 2 浮動小数点数 3 日付]
* ["font"] => フォント
* ["data"] = > データ
* ...
* }
*/
$data=$this->_excel_handle-> ; worksheet['data'][$i]['cell'][$j][$k];
switch($data['type'])
{
case 0:
//文字型
if( $ this->_excel_handle->sst['unicode'][$data['data']])
{
//中国語処理
$data['data'] = $this->uc2html($this - >_excel_handle->sst['data'][$data['data']]);
}
else
{
$data['data'] = $this->_excel_handle->sst[ ' data'][$data['data']];
break;
ケース 1:
//整数
//TODO
break;
//浮動小数点
//TODO
break;ケース 3:
//Date
//TODO
break;
$this->_data[1][$i][$j][$k]=$data['data']; $data);
}
}
}
}
/**
* メイン関数
* @return <array> array(識別子, 内容)
*/
public function main()
{
//Excel 情報を取得する
$this->getExcelInfo();取得
$this->getExcelData();
return $this->_data
}
;
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

人気の記事
スプリットフィクションを打ち負かすのにどれくらい時間がかかりますか?
3週間前
By DDD
レポ:チームメイトを復活させる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
ハローキティアイランドアドベンチャー:巨大な種を手に入れる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
2つのポイント博物館:すべての展示とそれらを見つける場所
3週間前
By 尊渡假赌尊渡假赌尊渡假赌

人気の記事
スプリットフィクションを打ち負かすのにどれくらい時間がかかりますか?
3週間前
By DDD
レポ:チームメイトを復活させる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
ハローキティアイランドアドベンチャー:巨大な種を手に入れる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
2つのポイント博物館:すべての展示とそれらを見つける場所
3週間前
By 尊渡假赌尊渡假赌尊渡假赌

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック
Gmailメールのログイン入り口はどこですか?
7125
9


Java チュートリアル
1534
14


Laravel チュートリアル
1256
25


PHP チュートリアル
1205
29


CakePHP チュートリアル
1153
46



Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法
