71 lines
1.6 KiB
PHP
71 lines
1.6 KiB
PHP
<?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>
|
|
|
|
<h1>PHPExcel Reader Example #09</h1>
|
|
<h2>Simple File Reader Using a Read Filter</h2>
|
|
<?php
|
|
|
|
/** Include path **/
|
|
set_include_path(get_include_path() . PATH_SEPARATOR . '../../../Classes/');
|
|
|
|
/** PHPExcel_IOFactory */
|
|
include 'PHPExcel/IOFactory.php';
|
|
|
|
|
|
$inputFileType = 'Excel5';
|
|
// $inputFileType = 'Excel2007';
|
|
// $inputFileType = 'Excel2003XML';
|
|
// $inputFileType = 'OOCalc';
|
|
// $inputFileType = 'Gnumeric';
|
|
$inputFileName = './sampleData/example1.xls';
|
|
$sheetname = 'Data Sheet #3';
|
|
|
|
|
|
class MyReadFilter implements PHPExcel_Reader_IReadFilter
|
|
{
|
|
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 />';
|
|
$objReader = PHPExcel_IOFactory::createReader($inputFileType);
|
|
echo 'Loading Sheet "',$sheetname,'" only<br />';
|
|
$objReader->setLoadSheetsOnly($sheetname);
|
|
echo 'Loading Sheet using filter<br />';
|
|
$objReader->setReadFilter($filterSubset);
|
|
$objPHPExcel = $objReader->load($inputFileName);
|
|
|
|
|
|
echo '<hr />';
|
|
|
|
$sheetData = $objPHPExcel->getActiveSheet()->toArray(null,true,true,true);
|
|
var_dump($sheetData);
|
|
|
|
|
|
?>
|
|
<body>
|
|
</html>
|