PhpSpreadsheet/tests/PhpSpreadsheetTests/Calculation/Functions/Information/IsFormulaTest.php

115 lines
5.2 KiB
PHP

<?php
namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\Information;
use PhpOffice\PhpSpreadsheet\Calculation\Calculation;
use PhpOffice\PhpSpreadsheet\Cell\DataType;
use PhpOffice\PhpSpreadsheet\NamedRange as NamedRange;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PHPUnit\Framework\TestCase;
class IsFormulaTest extends TestCase
{
public function testIsFormula(): void
{
$spreadsheet = new Spreadsheet();
$sheet1 = $spreadsheet->getActiveSheet();
$sheet1->setTitle('SheetOne'); // no space in sheet title
$sheet2 = $spreadsheet->createSheet();
$sheet2->setTitle('Sheet Two'); // space in sheet title
$values = [
[null, false],
[-1, false],
[0, false],
[1, false],
['', false],
[false, false],
[true, false],
['=-1', true],
['="ABC"', true],
['=SUM(1,2,3)', true],
];
$row = 0;
foreach ($values as $valArray) {
++$row;
if ($valArray[0] !== null) {
$sheet1->getCell("A$row")->setValue($valArray[0]);
}
$sheet1->getCell("B$row")->setValue("=ISFORMULA(A$row)");
self::assertSame($valArray[1], $sheet1->getCell("B$row")->getCalculatedValue(), "sheet1 error in B$row");
}
$row = 0;
foreach ($values as $valArray) {
++$row;
if ($valArray[0] !== null) {
$sheet2->getCell("A$row")->setValue($valArray[0]);
}
$sheet2->getCell("B$row")->setValue("=ISFORMULA(A$row)");
self::assertSame($valArray[1], $sheet2->getCell("B$row")->getCalculatedValue(), "sheet2 error in B$row");
}
$sheet1->getCell('C1')->setValue(0);
$sheet1->getCell('C2')->setValue('=0');
$sheet2->getCell('C3')->setValue(0);
$sheet2->getCell('C4')->setValue('=0');
$sheet1->getCell('D1')->setValue('=ISFORMULA(SheetOne!C1)');
$sheet1->getCell('D2')->setValue('=ISFORMULA(SheetOne!C2)');
$sheet1->getCell('E1')->setValue('=ISFORMULA(\'SheetOne\'!C1)');
$sheet1->getCell('E2')->setValue('=ISFORMULA(\'SheetOne\'!C2)');
$sheet1->getCell('F1')->setValue('=ISFORMULA(\'Sheet Two\'!C3)');
$sheet1->getCell('F2')->setValue('=ISFORMULA(\'Sheet Two\'!C4)');
self::assertFalse($sheet1->getCell('D1')->getCalculatedValue());
self::assertTrue($sheet1->getCell('D2')->getCalculatedValue());
self::assertFalse($sheet1->getCell('E1')->getCalculatedValue());
self::assertTrue($sheet1->getCell('E2')->getCalculatedValue());
self::assertFalse($sheet1->getCell('F1')->getCalculatedValue());
self::assertTrue($sheet1->getCell('F2')->getCalculatedValue());
$spreadsheet->addNamedRange(new NamedRange('range1f', $sheet1, '$C$1'));
$spreadsheet->addNamedRange(new NamedRange('range1t', $sheet1, '$C$2'));
$spreadsheet->addNamedRange(new NamedRange('range2f', $sheet2, '$C$3'));
$spreadsheet->addNamedRange(new NamedRange('range2t', $sheet2, '$C$4'));
$spreadsheet->addNamedRange(new NamedRange('range2ft', $sheet2, '$C$3:$C$4'));
$sheet1->getCell('G1')->setValue('=ISFORMULA(ABCDEFG)');
$sheet1->getCell('G3')->setValue('=ISFORMULA(range1f)');
$sheet1->getCell('G4')->setValue('=ISFORMULA(range1t)');
$sheet1->getCell('G5')->setValue('=ISFORMULA(range2f)');
$sheet1->getCell('G6')->setValue('=ISFORMULA(range2t)');
$sheet1->getCell('G7')->setValue('=ISFORMULA(range2ft)');
self::assertSame('#NAME?', $sheet1->getCell('G1')->getCalculatedValue());
self::assertFalse($sheet1->getCell('G3')->getCalculatedValue());
self::assertTrue($sheet1->getCell('G4')->getCalculatedValue());
self::assertFalse($sheet1->getCell('G5')->getCalculatedValue());
self::assertTrue($sheet1->getCell('G6')->getCalculatedValue());
self::assertFalse($sheet1->getCell('G7')->getCalculatedValue());
$sheet1->getCell('H1')->setValue('=ISFORMULA(C1:C2)');
$sheet1->getCell('H3')->setValue('=ISFORMULA(C2:C3)');
self::assertFalse($sheet1->getCell('H1')->getCalculatedValue());
self::assertTrue($sheet1->getCell('H3')->getCalculatedValue());
$spreadsheet->disconnectWorksheets();
}
public function testIsFormulaArray(): void
{
$spreadsheet = new Spreadsheet();
$sheet = $spreadsheet->getActiveSheet();
$sheet->getCell('A1')->setValue('=5/2');
$sheet->getCell('A2')->setValueExplicit('=5/2', DataType::TYPE_STRING);
$sheet->getCell('A3')->setValue('=5/0');
$sheet->getCell('A4')->setValue(2.5);
$sheet->getCell('A5')->setValue('=NA()');
$sheet->getCell('A6')->setValue(true);
$sheet->getCell('A7')->setValue('=5/0');
$sheet->getCell('A7')->getStyle()->setQuotePrefix(true);
$calculation = Calculation::getInstance($spreadsheet);
$formula = '=ISFORMULA(A1:A7)';
$result = $calculation->_calculateFormulaValue($formula, 'C1', $sheet->getCell('C1'));
self::assertEquals([true, false, true, false, true, false, false], $result);
$spreadsheet->disconnectWorksheets();
}
}