| Conditions | 9 |
| Paths | 11 |
| Total Lines | 31 |
| Code Lines | 16 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 0 | ||
| 1 | <?php |
||
| 23 | public static function autoMergeColumns( |
||
| 24 | Worksheet $worksheet, |
||
| 25 | array $mergeColumns, |
||
| 26 | array $fields, |
||
| 27 | int $rowStart, |
||
| 28 | int $rowEnd |
||
| 29 | ) { |
||
| 30 | if ($rowEnd <= $rowStart) return; |
||
| 31 | |||
| 32 | foreach ($mergeColumns as $fieldName) { |
||
| 33 | $colIdx = array_search($fieldName, $fields); |
||
| 34 | if ($colIdx === false) continue; |
||
| 35 | |||
| 36 | $colLetter = WorkSheetHelper::cellName($colIdx); |
||
|
|
|||
| 37 | $lastValue = null; |
||
| 38 | $mergeStart = $rowStart; |
||
| 39 | |||
| 40 | for ($row = $rowStart; $row <= $rowEnd; $row++) { |
||
| 41 | $cellValue = $worksheet->getCell($colLetter . $row)->getValue(); |
||
| 42 | if ($lastValue !== null && $cellValue !== $lastValue) { |
||
| 43 | if ($row - $mergeStart > 1) { |
||
| 44 | $worksheet->mergeCells($colLetter . $mergeStart . ':' . $colLetter . ($row - 1)); |
||
| 45 | } |
||
| 46 | $mergeStart = $row; |
||
| 47 | } |
||
| 48 | $lastValue = $cellValue; |
||
| 49 | } |
||
| 50 | |||
| 51 | // 处理最后一组 |
||
| 52 | if ($rowEnd - $mergeStart + 1 > 1) { |
||
| 53 | $worksheet->mergeCells($colLetter . $mergeStart . ':' . $colLetter . $rowEnd); |
||
| 54 | } |
||
| 59 |