PHPExcelを使用してテーブルの内容を読み取る方法

不言
リリース: 2023-04-03 10:04:02
オリジナル
3604 人が閲覧しました

PHPExcel を使用してテーブルの内容を読み取るにはどうすればよいですか?早速、次の記事で PHPExcel でテーブルの内容を読み取る方法を詳しく紹介します。

最初にクラス IOFactory.phpを導入します

require_once '../PHPExcel/IOFactory.php';
$filePath = "test.xlsx";  // 测试文件
ログイン後にコピー

テスト ファイルをロードします

  1. ##$inputFileType = PHPExcel_IOFactory::identify($ filePath ) ファイルの種類を決定します

  2. $objReader = PHPExcel_IOFactory::createReader($inputFileType); 型オブジェクトをインスタンス化します

  3. $objPHPExcel = $ objReader- >load($filePath); ファイルの読み込み

主に、次の内容によって Excel2007 および Excel5 の種類、つまり xlsx/xlsm/xltx/xltm および xls/xlt 形式のファイルが決まります

try {
    $inputFileType = PHPExcel_IOFactory::identify($filePath);
    if ($inputFileType !== "Excel5" && $inputFileType !== "Excel2007" ) {
        unlink($filePath) && str_alert(-1,"请确保导入的文件格式正确!");
    }
    $objReader = PHPExcel_IOFactory::createReader($inputFileType);
    $objPHPExcel = $objReader->load($filePath);
} catch(Exception $e) {
    unlink($filePath) && str_alert(-1,'加载文件发生错误:”'.pathinfo($filePath,PATHINFO_BASENAME).'”: '.$e->getMessage());
    }
ログイン後にコピー
現在のワークシートを取得します

$sheet = $objPHPExcel->getSheet(0);
//或者
$sheet = $objPHPExcel->getActiveSheet();
ログイン後にコピー

ワークシートの行と列の数を取得します

$highestRow = $sheet->getHighestRow();
$highestColumn = $sheet->getHighestColumn();
ログイン後にコピー

注: テーブルのコンテンツが明らかに 5 行しかないことがわかる場合があります。しかし、「The $highestRow has 7, 8 or more rows. これは、フォームを操作するときに誤って他の行をクリックしたことが原因である可能性があります。内容は入力されていませんが、getHighestRow は行番号も識別できます。

と思います」コンテンツを含む行数を取得するには、getHighestDataRow と getHighestDataColumn を使用する必要があります。
ソース コードのコメントでは、文字列「データを含む最大行番号」、つまり、データを含む文字列の最大行番号が導入されています。

セルの具体的な内容

xlsx タイプのテーブルのセルは、同様の xy 軸座標によって取得されます。

は、同様の

 $sheet->getCell("A1")->getValue();
 $sheet->getCell("B2")->getValue();
ログイン後にコピー
,# を通じて、対応する位置の内容を取得できます。 ## 文字を使用したくない場合は、トラバースして取得するには、数値インデックス メソッドを使用できます。

  $sheet->getCellByColumnAndRow(0,1);
  $sheet->getCellByColumnAndRow(1,2);
ログイン後にコピー

座標の最初のパラメータは 0 から始まり、0 は A を表し、1 は B を表すことに注意してください。 ..、2 番目のパラメータは 1 から始まります。 以下は、すべてのセルの内容を取得するためにテーブルを走査することです:

$dataSet=array();
for ($column = "A"; $column <= $highestColumn; $column++) {//列数是以A列开始
    for ($row = 4; $row <= $highestRow; $row++) { //行数是以第4行开始
        $cell = $sheet->getCell($column . $row)->getValue();
        if($cell instanceof PHPExcel_RichText) { //富文本转换字符串
            $cell = $cell->__toString();
        }
        $dataSet[$row][] = $cell;
    }
}
ログイン後にコピー

その中で、リッチ テキスト変換文字列は $cell instanceof PHPExcel_RichText を使用して、リッチ テキストかどうかを判断します。データを調べた結果、セル内の文字列に上記のフォントが 2 つ含まれている場合、自動的にリッチ テキストに設定されます。このとき、__toString() 変換が必要です。

結合されたセルが左上隅にあるかどうかを判断するには、

すべてのセルをループして出力すると、一部の結合されたセルには左上座標の内容のみが含まれ、その他のセルは null であることがわかります。

たとえば、A4 と A5 が 1 つのセルにマージされる場合、getCell("A4") には通常の内容が含まれますが、getCell("A5" ") は null になります。

isMergeRangeValueCell を使用して、特定のセルがセルに含まれるかどうかを判断できます。は左上隅です

$sheet->getCell('A' . $row)->isMergeRangeValueCell()
ログイン後にコピー

$rowが4の場合はtrueを返し、5の場合はfalseを返します

変換時間

の内容を取得するにはテーブル内の時刻形式 PHPExcel_Shared_Date::ExcelToPHP() は、PHP で認識できる時刻形式に変換する必要があります

date('Y-m-d',PHPExcel_Shared_Date::ExcelToPHP($sometime);
ログイン後にコピー

関連する推奨事項:

phpexcel の例Excel テーブル時刻の読み取り

PHPExcel Excel テーブル時刻セルを正しく読み取る

以上がPHPExcelを使用してテーブルの内容を読み取る方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
php
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート