From 12b27e1f114f62d40f13b1dc226fbe907b4ab11d Mon Sep 17 00:00:00 2001 From: rafageist Date: Wed, 17 Jan 2024 00:13:11 -0300 Subject: [PATCH] grouping --- examples/grouping.php | 37 +++++++++++++++++++++++++++++++++++++ src/matrix.php | 4 ---- 2 files changed, 37 insertions(+), 4 deletions(-) create mode 100644 examples/grouping.php diff --git a/examples/grouping.php b/examples/grouping.php new file mode 100644 index 0000000..0076315 --- /dev/null +++ b/examples/grouping.php @@ -0,0 +1,37 @@ +formatTXT(true); + +// Group by +$result = $table->groupBy([0], function($key, $group){ + $sum = 0; + foreach($group as $row){ + $sum += $row[1]; + } + return [$key, $sum]; +}, true); + +echo "\n"; +$groupBy = new matrix(array_values($result)); +$groupBy->addRow(["Product", "Total"], onTop: true); +echo $groupBy->formatTXT(true); + diff --git a/src/matrix.php b/src/matrix.php index 9a3ef7f..c98a392 100644 --- a/src/matrix.php +++ b/src/matrix.php @@ -88,10 +88,6 @@ public function __construct(array $matrix) */ public function validateMatrix(array $matrix): void { - if (empty($matrix) || !is_array($matrix[0]) || empty($matrix[0])) { - throw new InvalidArgumentException('Matrix must have at least one row with string headers'); - } - $numColumns = count($matrix[0]); foreach ($matrix as $row) { if (!is_array($row) || count($row) !== $numColumns) {