You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
50 lines
1.7 KiB
50 lines
1.7 KiB
<?php
|
|
|
|
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
|
|
|
require __DIR__ . '/../../Header.php';
|
|
|
|
$helper->log('Returns the depreciation of an asset, using the Fixed Declining Balance Method,');
|
|
$helper->log('for each period of the asset\'s lifetime.');
|
|
|
|
// Create new PhpSpreadsheet object
|
|
$spreadsheet = new Spreadsheet();
|
|
$worksheet = $spreadsheet->getActiveSheet();
|
|
|
|
// Add some data
|
|
$arguments = [
|
|
['Cost Value', 10000],
|
|
['Salvage', 1000],
|
|
['Life', 5, 'Years'],
|
|
];
|
|
|
|
// Some basic formatting for the data
|
|
$worksheet->fromArray($arguments, null, 'A1');
|
|
$worksheet->getStyle('B1:B2')->getNumberFormat()->setFormatCode('$#,##0.00');
|
|
|
|
// Now the formula
|
|
$baseRow = 5;
|
|
for ($year = 1; $year <= 5; ++$year) {
|
|
$row = (string) ($baseRow + $year);
|
|
|
|
$worksheet->setCellValue("A{$row}", "Depreciation after Yr {$year}");
|
|
$worksheet->setCellValue("B{$row}", "=DB(\$B\$1, \$B\$2, \$B\$3, {$year})");
|
|
$worksheet->getStyle("B{$row}")->getNumberFormat()->setFormatCode('$#,##0.00;-$#,##0.00');
|
|
|
|
$helper->log($worksheet->getCell("B{$row}")->getValue());
|
|
$helper->log("DB() Year {$year} Result is " . $worksheet->getCell("B{$row}")->getFormattedValue());
|
|
}
|
|
|
|
$helper->log('And with depreciation only starting after 6 months.');
|
|
|
|
$baseRow = 12;
|
|
for ($year = 1; $year <= 6; ++$year) {
|
|
$row = (string) ($baseRow + $year);
|
|
|
|
$worksheet->setCellValue("A{$row}", "Depreciation after Yr {$year}");
|
|
$worksheet->setCellValue("B{$row}", "=DB(\$B\$1, \$B\$2, \$B\$3, {$year}, 6)");
|
|
$worksheet->getStyle("B{$row}")->getNumberFormat()->setFormatCode('$#,##0.00;-$#,##0.00');
|
|
|
|
$helper->log($worksheet->getCell("B{$row}")->getValue());
|
|
$helper->log("DB() Year {$year} Result is " . $worksheet->getCell("B{$row}")->getFormattedValue());
|
|
}
|
|
|