TextSplitTest.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\TextData;
  3. use PhpOffice\PhpSpreadsheet\Calculation\Calculation;
  4. use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
  5. class TextSplitTest extends AllSetupTeardown
  6. {
  7. private function setDelimiterArgument(array $argument, string $column): string
  8. {
  9. return '{' . $column . implode(',' . $column, range(1, count($argument))) . '}';
  10. }
  11. /**
  12. * @param array|string $argument
  13. */
  14. private function setDelimiterValues(Worksheet $worksheet, string $column, $argument): void
  15. {
  16. if (is_array($argument)) {
  17. foreach ($argument as $index => $value) {
  18. ++$index;
  19. $worksheet->getCell("{$column}{$index}")->setValue($value);
  20. }
  21. } else {
  22. $worksheet->getCell("{$column}1")->setValue($argument);
  23. }
  24. }
  25. /**
  26. * @dataProvider providerTEXTSPLIT
  27. */
  28. public function testTextSplit(array $expectedResult, array $arguments): void
  29. {
  30. $text = $arguments[0];
  31. $columnDelimiter = $arguments[1];
  32. $rowDelimiter = $arguments[2];
  33. $args = 'A1';
  34. $args .= (is_array($columnDelimiter)) ? ', ' . $this->setDelimiterArgument($columnDelimiter, 'B') : ', B1';
  35. $args .= (is_array($rowDelimiter)) ? ', ' . $this->setDelimiterArgument($rowDelimiter, 'C') : ', C1';
  36. $args .= (isset($arguments[3])) ? ", {$arguments[3]}" : ',';
  37. $args .= (isset($arguments[4])) ? ", {$arguments[4]}" : ',';
  38. $args .= (isset($arguments[5])) ? ", {$arguments[5]}" : ',';
  39. $worksheet = $this->getSheet();
  40. $worksheet->getCell('A1')->setValue($text);
  41. $this->setDelimiterValues($worksheet, 'B', $columnDelimiter);
  42. $this->setDelimiterValues($worksheet, 'C', $rowDelimiter);
  43. $worksheet->getCell('H1')->setValue("=TEXTSPLIT({$args})");
  44. $result = Calculation::getInstance($this->getSpreadsheet())->calculateCellValue($worksheet->getCell('H1'));
  45. self::assertSame($expectedResult, $result);
  46. }
  47. public function providerTEXTSPLIT(): array
  48. {
  49. return require 'tests/data/Calculation/TextData/TEXTSPLIT.php';
  50. }
  51. }