1)) { $inputFileNames = []; for ($i = 1; $i < $argc; ++$i) { $inputFileNames[] = __DIR__ . '/../templates/' . $argv[$i]; } } else { $inputFileNames = glob($inputFileNames); } if (count($inputFileNames) === 1) { $unresolvedErrors = []; } else { $unresolvedErrors = [ // The following spreadsheet was created by 3rd party software, // and doesn't include the data that usually accompanies a chart. // That is good enough for Excel, but not for JpGraph. '32readwriteBubbleChart2.xlsx', ]; } foreach ($inputFileNames as $inputFileName) { $inputFileNameShort = basename($inputFileName); if (!file_exists($inputFileName)) { $helper->log('File ' . $inputFileNameShort . ' does not exist'); continue; } if (in_array($inputFileNameShort, $unresolvedErrors, true)) { $helper->log('*****'); $helper->log('***** File ' . $inputFileNameShort . ' does not yet work with this script'); $helper->log('*****'); continue; } $helper->log("Load Test from $inputFileType file " . $inputFileNameShort); $reader = IOFactory::createReader($inputFileType); $reader->setIncludeCharts(true); $spreadsheet = $reader->load($inputFileName); $helper->log('Iterate worksheets looking at the charts'); foreach ($spreadsheet->getWorksheetIterator() as $worksheet) { $sheetName = $worksheet->getTitle(); $helper->log('Worksheet: ' . $sheetName); $chartNames = $worksheet->getChartNames(); if (empty($chartNames)) { $helper->log(' There are no charts in this worksheet'); } else { natsort($chartNames); foreach ($chartNames as $i => $chartName) { $chart = $worksheet->getChartByName($chartName); if ($chart->getTitle() !== null) { $caption = '"' . implode(' ', $chart->getTitle()->getCaption()) . '"'; } else { $caption = 'Untitled'; } $helper->log(' ' . $chartName . ' - ' . $caption); $jpegFile = $helper->getFilename('35-' . $inputFileNameShort, 'png'); if ($i !== 0) { $jpegFile = substr($jpegFile, 0, -3) . "$i.png"; } if (file_exists($jpegFile)) { unlink($jpegFile); } try { $chart->render($jpegFile); $helper->log('Rendered image: ' . $jpegFile); } catch (Exception $e) { $helper->log('Error rendering chart: ' . $e->getMessage()); } } } } $spreadsheet->disconnectWorksheets(); unset($spreadsheet); gc_collect_cycles(); } $helper->log('Done rendering charts as images');