Просто хотите распечатать данные ячеек из файла excel с помощью PHPExcel?


<?php

error_reporting(E_ALL);
set_time_limit(0);

date_default_timezone_set('Europe/London');

?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />

<title>PHPExcel Reader Example #09</title>

</head>
<body>


<?php

/** Include path **/
set_include_path(get_include_path() . PATH_SEPARATOR . '../../../Classes/');

/** PHPExcel_IOFactory */
include 'C:\webserver\www\Classes\PHPExcel\IOFactory.php';


$inputFileType = 'Excel5';
//  $inputFileType = 'Excel2007';
//  $inputFileType = 'Excel2003XML';
//  $inputFileType = 'OOCalc';
//  $inputFileType = 'Gnumeric';
$inputFileName = './sampleData/Book1.xls';
$sheetname = 'Data Sheet #3';


class MyReadFilter implements PHPExcel_Reader_IReadFilter
{
    public function readCell($column, $row, $worksheetName = '') {

        if ($row >= 1 && $row <= 1) {
            if (in_array($column,range('A','A'))) {
                return true;
            }
        }
        return false;
    }
}

$filterSubset = new MyReadFilter();

$objReader = PHPExcel_IOFactory::createReader($inputFileType);
$objReader->setLoadSheetsOnly($sheetname);
$objReader->setReadFilter($filterSubset);
$objPHPExcel = $objReader->load($inputFileName);
$sheetData = $objPHPExcel->getActiveSheet()->toArray(null,true,true,true);
var_dump($sheetData);


?>
<body>
</html>

Когда я запускаю код aboce, он выдает мне этот вывод

array(1) { [1]=> array(1) { ["A"]=> string(6) "ABCDEF" } }

В приведенном выше выводе ABCDEF - это данные первой ячейки. поэтому я хочу только ABCDEF, а не другие вещи, как показано выше.

Author: OneMore, 2012-12-31

2 answers

Это потому, что вы попросили PHPExcel предоставить вам весь рабочий лист в виде массива.

Если вам просто нужно значение ячейки A1, используйте:

$objPHPExcel->getActiveSheet()->getCell('A1')->getValue();

Вместо

$objPHPExcel->getActiveSheet()->toArray(null,true,true,true);

Подробнее об этом в документации, в данном случае в файле "Документация разработчика PHPExcel.pdf".

Затем вы также можете полностью удалить фильтр чтения. Ячейки считываются ленивым способом, поэтому вы ничего не сохраняете с помощью фильтра чтения, если получаете доступ только к ячейке A1 во всяком случае, напрямую.

 4
Author: AndreKR, 2012-12-31 04:29:11

Включить 'C:\webserver\www\Classes\PHPExcel\IOFactory.php';

Этот файл включает в себя файл, который включен мной в этот файл.

 0
Author: umesh, 2013-12-10 09:11:52