50a0ec58af
Closes #17
49 lines
1.7 KiB
PHP
49 lines
1.7 KiB
PHP
<?php
|
|
|
|
use PhpOffice\PhpSpreadsheet\IOFactory;
|
|
|
|
require __DIR__ . '/../Header.php';
|
|
|
|
$inputFileType = 'Xlsx';
|
|
$inputFileName = __DIR__ . '/sampleData/example1.xlsx';
|
|
|
|
/* Create a new Reader of the type defined in $inputFileType * */
|
|
$reader = IOFactory::createReader($inputFileType);
|
|
/* Load $inputFileName to a PhpSpreadsheet Object * */
|
|
$spreadsheet = $reader->load($inputFileName);
|
|
|
|
/* Read an array list of any custom properties for this document * */
|
|
$customPropertyList = $spreadsheet->getProperties()->getCustomProperties();
|
|
|
|
/* Loop through the list of custom properties * */
|
|
foreach ($customPropertyList as $customPropertyName) {
|
|
$helper->log('<b>' . $customPropertyName . ': </b>');
|
|
/* Retrieve the property value * */
|
|
$propertyValue = $spreadsheet->getProperties()->getCustomPropertyValue($customPropertyName);
|
|
/* Retrieve the property type * */
|
|
$propertyType = $spreadsheet->getProperties()->getCustomPropertyType($customPropertyName);
|
|
|
|
/* Manipulate properties as appropriate for display purposes * */
|
|
switch ($propertyType) {
|
|
case 'i': // integer
|
|
$propertyType = 'integer number';
|
|
break;
|
|
case 'f': // float
|
|
$propertyType = 'floating point number';
|
|
break;
|
|
case 's': // string
|
|
$propertyType = 'string';
|
|
break;
|
|
case 'd': // date
|
|
$propertyValue = date('l, d<\s\up>S</\s\up> F Y g:i A', $propertyValue);
|
|
$propertyType = 'date';
|
|
break;
|
|
case 'b': // boolean
|
|
$propertyValue = ($propertyValue) ? 'TRUE' : 'FALSE';
|
|
$propertyType = 'boolean';
|
|
break;
|
|
}
|
|
|
|
$helper->log($propertyValue . ' (' . $propertyType . ')');
|
|
}
|