36 lines
1.5 KiB
PHP
36 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Style;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
|
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
class NumberFormatBuiltinTest extends TestCase
|
|
{
|
|
public function testBuiltinCodes(): void
|
|
{
|
|
$spreadsheet = new Spreadsheet();
|
|
$sheet = $spreadsheet->getActiveSheet();
|
|
$cell1 = $sheet->getCell('A1');
|
|
$cell1->setValue(1);
|
|
$cell1->getStyle()->getNumberFormat()->setBuiltInFormatCode(2); // 0.00
|
|
self::assertEquals('1.00', $cell1->getFormattedValue());
|
|
$cell2 = $sheet->getCell('A2');
|
|
$cell2->setValue(1234);
|
|
$cell2->getStyle()->getNumberFormat()->setFormatCode('#,##0'); // builtin 3
|
|
self::assertEquals(3, $cell2->getStyle()->getNumberFormat()->getBuiltinFormatCode());
|
|
self::assertEquals('1,234', $cell2->getFormattedValue());
|
|
$cell3 = $sheet->getCell('A3');
|
|
$cell3->setValue(1234);
|
|
$cell3->getStyle()->getNumberFormat()->setFormatCode(''); // General
|
|
self::assertEquals(NumberFormat::FORMAT_GENERAL, $cell3->getStyle()->getNumberFormat()->getFormatCode());
|
|
self::assertEquals(0, $cell3->getStyle()->getNumberFormat()->getBuiltinFormatCode());
|
|
self::assertEquals('1234', $cell3->getFormattedValue());
|
|
// non-supervisor
|
|
$numberFormat = new NumberFormat();
|
|
$numberFormat->setBuiltInFormatCode(4);
|
|
self::assertEquals('#,##0.00', $numberFormat->getFormatCode());
|
|
}
|
|
}
|