PhpSpreadsheet/docs/Examples/Reader/exampleReader09.php

67 lines
1.6 KiB
PHP
Raw Normal View History

2016-11-27 06:45:15 +00:00
<?php
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>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
2017-03-24 13:09:32 +00:00
<title>PhpSpreadsheet Reader Example #09</title>
2016-11-27 06:45:15 +00:00
</head>
<body>
2017-03-24 13:09:32 +00:00
<h1>PhpSpreadsheet Reader Example #09</h1>
2016-11-27 06:45:15 +00:00
<h2>Simple File Reader Using a Read Filter</h2>
<?php
2017-03-24 13:09:32 +00:00
require_once __DIR__ . '/../../../src/Bootstrap.php';
2016-11-27 06:45:15 +00:00
$inputFileType = 'Xls';
// $inputFileType = 'Xlsx';
// $inputFileType = 'Xml';
2016-11-27 06:45:15 +00:00
// $inputFileType = 'Ods';
// $inputFileType = 'Gnumeric';
$inputFileName = './sampleData/example1.xls';
$sheetname = 'Data Sheet #3';
class MyReadFilter implements IReadFilter
2016-11-27 06:45:15 +00:00
{
public function readCell($column, $row, $worksheetName = '')
{
// Read rows 1 to 7 and columns A to E only
if ($row >= 1 && $row <= 7) {
if (in_array($column, range('A', 'E'))) {
return true;
}
}
return false;
}
}
$filterSubset = new MyReadFilter();
echo 'Loading file ',pathinfo($inputFileName, PATHINFO_BASENAME),' using IOFactory with a defined reader type of ',$inputFileType,'<br />';
$reader = IOFactory::createReader($inputFileType);
2016-11-27 06:45:15 +00:00
echo 'Loading Sheet "',$sheetname,'" only<br />';
$reader->setLoadSheetsOnly($sheetname);
2016-11-27 06:45:15 +00:00
echo 'Loading Sheet using filter<br />';
$reader->setReadFilter($filterSubset);
$spreadsheet = $reader->load($inputFileName);
2016-11-27 06:45:15 +00:00
echo '<hr />';
2016-11-27 15:51:44 +00:00
$sheetData = $spreadsheet->getActiveSheet()->toArray(null, true, true, true);
2016-11-27 06:45:15 +00:00
var_dump($sheetData);
?>
<body>
</html>