100 lines
3.4 KiB
PHP
100 lines
3.4 KiB
PHP
<?php
|
|
|
|
require __DIR__ . '/Header.php';
|
|
|
|
// Create new Spreadsheet object
|
|
$helper->log('Create new Spreadsheet object');
|
|
$spreadsheet = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
|
|
|
|
// Set document properties
|
|
$helper->log('Set document properties');
|
|
$spreadsheet->getProperties()->setCreator('Maarten Balliauw')
|
|
->setLastModifiedBy('Maarten Balliauw')
|
|
->setTitle('PhpSpreadsheet Test Document')
|
|
->setSubject('PhpSpreadsheet Test Document')
|
|
->setDescription('Test document for PhpSpreadsheet, generated using PHP classes.')
|
|
->setKeywords('office PhpSpreadsheet php')
|
|
->setCategory('Test result file');
|
|
|
|
// Create the worksheet
|
|
$helper->log('Add data');
|
|
$spreadsheet->setActiveSheetIndex(0);
|
|
$spreadsheet->getActiveSheet()->setCellValue('A1', 'Year')
|
|
->setCellValue('B1', 'Quarter')
|
|
->setCellValue('C1', 'Country')
|
|
->setCellValue('D1', 'Sales');
|
|
|
|
$dataArray = [
|
|
['2010', 'Q1', 'United States', 790],
|
|
['2010', 'Q2', 'United States', 730],
|
|
['2010', 'Q3', 'United States', 860],
|
|
['2010', 'Q4', 'United States', 850],
|
|
['2011', 'Q1', 'United States', 800],
|
|
['2011', 'Q2', 'United States', 700],
|
|
['2011', 'Q3', 'United States', 900],
|
|
['2011', 'Q4', 'United States', 950],
|
|
['2010', 'Q1', 'Belgium', 380],
|
|
['2010', 'Q2', 'Belgium', 390],
|
|
['2010', 'Q3', 'Belgium', 420],
|
|
['2010', 'Q4', 'Belgium', 460],
|
|
['2011', 'Q1', 'Belgium', 400],
|
|
['2011', 'Q2', 'Belgium', 350],
|
|
['2011', 'Q3', 'Belgium', 450],
|
|
['2011', 'Q4', 'Belgium', 500],
|
|
['2010', 'Q1', 'UK', 690],
|
|
['2010', 'Q2', 'UK', 610],
|
|
['2010', 'Q3', 'UK', 620],
|
|
['2010', 'Q4', 'UK', 600],
|
|
['2011', 'Q1', 'UK', 720],
|
|
['2011', 'Q2', 'UK', 650],
|
|
['2011', 'Q3', 'UK', 580],
|
|
['2011', 'Q4', 'UK', 510],
|
|
['2010', 'Q1', 'France', 510],
|
|
['2010', 'Q2', 'France', 490],
|
|
['2010', 'Q3', 'France', 460],
|
|
['2010', 'Q4', 'France', 590],
|
|
['2011', 'Q1', 'France', 620],
|
|
['2011', 'Q2', 'France', 650],
|
|
['2011', 'Q3', 'France', 415],
|
|
['2011', 'Q4', 'France', 570],
|
|
['2010', 'Q1', 'Germany', 720],
|
|
['2010', 'Q2', 'Germany', 680],
|
|
['2010', 'Q3', 'Germany', 640],
|
|
['2010', 'Q4', 'Germany', 660],
|
|
['2011', 'Q1', 'Germany', 680],
|
|
['2011', 'Q2', 'Germany', 620],
|
|
['2011', 'Q3', 'Germany', 710],
|
|
['2011', 'Q4', 'Germany', 690],
|
|
['2010', 'Q1', 'Spain', 510],
|
|
['2010', 'Q2', 'Spain', 490],
|
|
['2010', 'Q3', 'Spain', 470],
|
|
['2010', 'Q4', 'Spain', 420],
|
|
['2011', 'Q1', 'Spain', 460],
|
|
['2011', 'Q2', 'Spain', 390],
|
|
['2011', 'Q3', 'Spain', 430],
|
|
['2011', 'Q4', 'Spain', 415],
|
|
['2010', 'Q1', 'Italy', 440],
|
|
['2010', 'Q2', 'Italy', 410],
|
|
['2010', 'Q3', 'Italy', 420],
|
|
['2010', 'Q4', 'Italy', 450],
|
|
['2011', 'Q1', 'Italy', 430],
|
|
['2011', 'Q2', 'Italy', 370],
|
|
['2011', 'Q3', 'Italy', 350],
|
|
['2011', 'Q4', 'Italy', 335],
|
|
];
|
|
$spreadsheet->getActiveSheet()->fromArray($dataArray, null, 'A2');
|
|
|
|
// Set title row bold
|
|
$helper->log('Set title row bold');
|
|
$spreadsheet->getActiveSheet()->getStyle('A1:D1')->getFont()->setBold(true);
|
|
|
|
// Set autofilter
|
|
$helper->log('Set autofilter');
|
|
// Always include the complete filter range!
|
|
// Excel does support setting only the caption
|
|
// row, but that's not a best practise...
|
|
$spreadsheet->getActiveSheet()->setAutoFilter($spreadsheet->getActiveSheet()->calculateWorksheetDimension());
|
|
|
|
// Save
|
|
$helper->write($spreadsheet, __FILE__);
|