PhpSpreadsheet/docs/Examples/Reading WorkBook Data/exampleWorkBookReader03.php

75 lines
2.1 KiB
PHP
Raw Normal View History

<?php
use PhpOffice\PhpSpreadsheet\IOFactory;
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 Reading WorkBook Data Example #03</title>
</head>
<body>
2017-03-24 13:09:32 +00:00
<h1>PhpSpreadsheet Reading WorkBook Data Example #03</h1>
<h2>Read Custom Property Values for a WorkBook</h2>
<?php
2017-03-24 13:09:32 +00:00
require_once __DIR__ . '/../../../src/Bootstrap.php';
$inputFileType = 'Xlsx';
$inputFileName = './sampleData/example1.xlsx';
/* Create a new Reader of the type defined in $inputFileType **/
$reader = IOFactory::createReader($inputFileType);
2017-03-24 13:09:32 +00:00
/* Load $inputFileName to a PhpSpreadsheet Object **/
$spreadsheet = $reader->load($inputFileName);
echo '<hr />';
/* Read an array list of any custom properties for this document **/
2016-11-27 15:51:44 +00:00
$customPropertyList = $spreadsheet->getProperties()->getCustomProperties();
echo '<b>Custom Properties: </b><br />';
/* Loop through the list of custom properties **/
foreach ($customPropertyList as $customPropertyName) {
echo '<b>',$customPropertyName,': </b>';
/* Retrieve the property value **/
2016-11-27 15:51:44 +00:00
$propertyValue = $spreadsheet->getProperties()->getCustomPropertyValue($customPropertyName);
/* Retrieve the property type **/
2016-11-27 15:51:44 +00:00
$propertyType = $spreadsheet->getProperties()->getCustomPropertyType($customPropertyName);
/* Manipulate properties as appropriate for display purposes **/
switch ($propertyType) {
2017-01-05 03:14:44 +00:00
case 'i': // integer
$propertyType = 'integer number';
break;
2017-01-05 03:14:44 +00:00
case 'f': // float
$propertyType = 'floating point number';
break;
2017-01-05 03:14:44 +00:00
case 's': // string
$propertyType = 'string';
break;
2017-01-05 03:14:44 +00:00
case 'd': // date
$propertyValue = date('l, d<\s\up>S</\s\up> F Y g:i A', $propertyValue);
$propertyType = 'date';
break;
2017-01-05 03:14:44 +00:00
case 'b': // boolean
$propertyValue = ($propertyValue) ? 'TRUE' : 'FALSE';
$propertyType = 'boolean';
break;
}
2017-01-05 03:14:44 +00:00
echo $propertyValue, ' (', $propertyType, ')<br />';
}
?>
<body>
</html>