スプレッドシートを読むために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>';
}