2016-11-27 06:45:15 +00:00
|
|
|
<?php
|
|
|
|
|
2017-05-17 22:02:17 +00:00
|
|
|
use PhpOffice\PhpSpreadsheet\IOFactory;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Reader\IReadFilter;
|
|
|
|
|
2016-11-27 06:45:15 +00:00
|
|
|
error_reporting(E_ALL);
|
|
|
|
set_time_limit(0);
|
|
|
|
|
|
|
|
date_default_timezone_set('Europe/London');
|
|
|
|
?>
|
|
|
|
<html>
|
2017-08-03 10:03:24 +00:00
|
|
|
<head>
|
|
|
|
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
<title>PhpSpreadsheet Reader Example #10</title>
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
</head>
|
|
|
|
<body>
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
<h1>PhpSpreadsheet Reader Example #10</h1>
|
|
|
|
<h2>Simple File Reader Using a Configurable Read Filter</h2>
|
|
|
|
<?php
|
|
|
|
require_once __DIR__ . '/../../../src/Bootstrap.php';
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
$inputFileType = 'Xls';
|
|
|
|
$inputFileName = './sampleData/example1.xls';
|
|
|
|
$sheetname = 'Data Sheet #3';
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
class MyReadFilter implements IReadFilter
|
|
|
|
{
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
private $_startRow = 0;
|
|
|
|
private $_endRow = 0;
|
|
|
|
private $_columns = [];
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
public function __construct($startRow, $endRow, $columns)
|
|
|
|
{
|
|
|
|
$this->_startRow = $startRow;
|
|
|
|
$this->_endRow = $endRow;
|
|
|
|
$this->_columns = $columns;
|
|
|
|
}
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
public function readCell($column, $row, $worksheetName = '')
|
|
|
|
{
|
|
|
|
if ($row >= $this->_startRow && $row <= $this->_endRow) {
|
|
|
|
if (in_array($column, $this->_columns)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
return false;
|
2016-11-27 06:45:15 +00:00
|
|
|
}
|
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
}
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
$filterSubset = new MyReadFilter(9, 15, range('G', 'K'));
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
echo 'Loading file ', pathinfo($inputFileName, PATHINFO_BASENAME), ' using IOFactory with a defined reader type of ', $inputFileType, '<br />';
|
|
|
|
$reader = IOFactory::createReader($inputFileType);
|
|
|
|
echo 'Loading Sheet "', $sheetname, '" only<br />';
|
|
|
|
$reader->setLoadSheetsOnly($sheetname);
|
|
|
|
echo 'Loading Sheet using configurable filter<br />';
|
|
|
|
$reader->setReadFilter($filterSubset);
|
|
|
|
$spreadsheet = $reader->load($inputFileName);
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
echo '<hr />';
|
2016-11-27 06:45:15 +00:00
|
|
|
|
2017-08-03 10:03:24 +00:00
|
|
|
$sheetData = $spreadsheet->getActiveSheet()->toArray(null, true, true, true);
|
|
|
|
var_dump($sheetData);
|
|
|
|
?>
|
|
|
|
<body>
|
2010-10-12 21:32:17 +00:00
|
|
|
</html>
|