1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
| <?php
|
| use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
| require __DIR__ . '/../Header.php';
|
| // Create new Spreadsheet object
| $helper->log('Create new Spreadsheet object');
| $spreadsheet = new 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__);
|
|