0

スプレッドシートを読むためにPHPExcel libを使用しています。xlsx および xls ファイルでは正常に動作しますが、ods および ots では動作しません。

セルの背景色を取得しようとしていますが、ods ファイルを使用するFFFFFと、実際のセルの色の代わりに常に取得されます。

ここに私が取り組んでいるコードがあります:

$cantCOL = 5;
try {
    //file route
    $rutaArchivo = $_FILES["archivo"]["tmp_name"];
    //phpExcel Reader
    $objReader = PHPExcel_IOFactory::createReaderForFile($rutaArchivo);
    //ReadDataOnly false, to get cell color
    $objReader->setReadDataOnly(false);
    //load spreedsheet from file route
    $objLibro = $objReader->load($rutaArchivo);
    //set the active sheet
    $objLibro->setActiveSheetIndex(0);
    //get last row number
    $n = $objHoja->getHighestRow();
    //Loop through the rows
    for ($fila = 1; $fila <= $n; $fila++) {
        //Loop through the columns
        for($col = 0; $col < $cantCOL+2; $col++){
            $columnLetter = PHPExcel_Cell::stringFromColumnIndex($col);
            //get the cell color, RGB format
            $cellColor = $objLibro->getActiveSheet()->getStyle($columnLetter.$fila)
                              ->getFill()
                              ->getStartColor()
                              ->getRGB();
             if($cellColor!='000000' && $cellColor!='FFFFFF' && !$error){
                 //Show cell color
                 echo '<script language="javascript">alert("Color: "'.$cellColor.'");</script>';
             }else{
                 echo '<script language="javascript">alert("No Color");</script>';
             }
         }
     }
 } catch (Exception $e) {
     echo '<script language="javascript">alert("Error:"'.$e.'");</script>';
 }
4

0 に答える 0