2922a13764
This introduce a helper class that should be used to log things, avoiding a lot of boilerplate code. Also all output are made in /tmp folder instead of beside the script itself. This is because there is a high chance that the folder containing the script is not writtable by webserver. So using the /tmp folder makes it more likely to works in a variety of setup.
37 lines
1.1 KiB
PHP
37 lines
1.1 KiB
PHP
<?php
|
|
|
|
require __DIR__ . '/Header.php';
|
|
$spreadsheet = require __DIR__ . '/templates/sampleSpreadsheet.php';
|
|
|
|
$helper->log('Write to CSV format');
|
|
$writer = \PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'CSV')->setDelimiter(',')
|
|
->setEnclosure('"')
|
|
->setSheetIndex(0);
|
|
|
|
$callStartTime = microtime(true);
|
|
$filename = $helper->getTemporaryFilename('csv');
|
|
$writer->save($filename);
|
|
$helper->logWrite($writer, $filename, $callStartTime);
|
|
|
|
$helper->log('Read from CSV format');
|
|
|
|
$reader = \PhpSpreadsheet\IOFactory::createReader('CSV')->setDelimiter(',')
|
|
->setEnclosure('"')
|
|
->setSheetIndex(0);
|
|
|
|
$callStartTime = microtime(true);
|
|
$spreadsheetFromCSV = $reader->load($filename);
|
|
$helper->logRead('CSV', $filename, $callStartTime);
|
|
|
|
// Write Excel2007
|
|
$helper->write($spreadsheetFromCSV, __FILE__, ['Excel2007' => 'xlsx']);
|
|
|
|
// Write CSV
|
|
$filenameCSV = $helper->getFilename(__FILE__, 'csv');
|
|
$writerCSV = \PhpSpreadsheet\IOFactory::createWriter($spreadsheetFromCSV, 'CSV');
|
|
$writerCSV->setExcelCompatibility(true);
|
|
|
|
$callStartTime = microtime(true);
|
|
$writerCSV->save($filenameCSV);
|
|
$helper->logWrite($writerCSV, $filenameCSV, $callStartTime);
|