| 
									
										
										
										
											2016-11-27 06:45:15 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-17 22:02:17 +00:00
										 |  |  | use PhpOffice\PhpSpreadsheet\Spreadsheet; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-27 06:45:15 +00:00
										 |  |  | error_reporting(E_ALL); | 
					
						
							|  |  |  | set_time_limit(0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | date_default_timezone_set('Europe/London'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ?>
 | 
					
						
							|  |  |  | <html> | 
					
						
							|  |  |  | <head> | 
					
						
							|  |  |  | <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-27 15:51:44 +00:00
										 |  |  | <title>PhpSpreadsheet Calculation Examples</title> | 
					
						
							| 
									
										
										
										
											2016-11-27 06:45:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | </head> | 
					
						
							|  |  |  | <body> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <h1>DPRODUCT</h1> | 
					
						
							|  |  |  | <h2>Multiplies the values in a column of a list or database that match conditions that you specify.</h2> | 
					
						
							|  |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-24 13:09:32 +00:00
										 |  |  | require_once __DIR__ . '/../../../../src/Bootstrap.php'; | 
					
						
							| 
									
										
										
										
											2016-11-27 06:45:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-27 15:51:44 +00:00
										 |  |  | // Create new PhpSpreadsheet object
 | 
					
						
							| 
									
										
										
										
											2017-05-17 22:02:17 +00:00
										 |  |  | $spreadsheet = new Spreadsheet(); | 
					
						
							| 
									
										
										
										
											2016-11-27 15:51:44 +00:00
										 |  |  | $worksheet = $spreadsheet->getActiveSheet(); | 
					
						
							| 
									
										
										
										
											2016-11-27 06:45:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Add some data
 | 
					
						
							|  |  |  | $database = [['Tree',  'Height', 'Age', 'Yield', 'Profit'], | 
					
						
							|  |  |  |                    ['Apple',  18,       20,    14,      105.00], | 
					
						
							|  |  |  |                    ['Pear',   12,       12,    10,       96.00], | 
					
						
							|  |  |  |                    ['Cherry', 13,       14,     9,      105.00], | 
					
						
							|  |  |  |                    ['Apple',  14,       15,    10,       75.00], | 
					
						
							|  |  |  |                    ['Pear',    9,        8,     8,       76.80], | 
					
						
							|  |  |  |                    ['Apple',   8,        9,     6,       45.00], | 
					
						
							|  |  |  |                  ]; | 
					
						
							|  |  |  | $criteria = [['Tree',      'Height', 'Age', 'Yield', 'Profit', 'Height'], | 
					
						
							|  |  |  |                    ['="=Apple"', '>10',    null,  null,    null,     '<16'], | 
					
						
							|  |  |  |                    ['="=Pear"',  null,     null,  null,    null,     null], | 
					
						
							|  |  |  |                  ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $worksheet->fromArray($criteria, null, 'A1'); | 
					
						
							|  |  |  | $worksheet->fromArray($database, null, 'A4'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $worksheet->setCellValue('A12', 'The product of the yields of all Apple trees over 10\' in the orchard'); | 
					
						
							|  |  |  | $worksheet->setCellValue('B12', '=DPRODUCT(A4:E10,"Yield",A1:B2)'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | echo '<hr />'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | echo '<h4>Database</h4>'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $databaseData = $worksheet->rangeToArray('A4:E10', null, true, true, true); | 
					
						
							|  |  |  | var_dump($databaseData); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | echo '<hr />'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Test the formulae
 | 
					
						
							|  |  |  | echo '<h4>Criteria</h4>'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | echo 'ALL' . '<br /><br />'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | echo $worksheet->getCell('A12')->getValue() . '<br />'; | 
					
						
							|  |  |  | echo 'DMAX() Result is ' . $worksheet->getCell('B12')->getCalculatedValue() . '<br /><br />'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | echo '<h4>Criteria</h4>'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $criteriaData = $worksheet->rangeToArray('A1:A2', null, true, true, true); | 
					
						
							|  |  |  | var_dump($criteriaData); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | echo $worksheet->getCell('A13')->getValue() . '<br />'; | 
					
						
							|  |  |  | echo 'DMAX() Result is ' . $worksheet->getCell('B13')->getCalculatedValue(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ?>
 | 
					
						
							|  |  |  | <body> | 
					
						
							| 
									
										
										
										
											2012-05-25 06:46:09 +00:00
										 |  |  | </html> |