mirror of
https://github.com/retailcrm/PHPExcel.git
synced 2024-11-26 07:16:03 +03:00
Some refactoring of insert/delete row/column reference methods
This commit is contained in:
parent
db1fcd5cd6
commit
7f7b520652
@ -106,10 +106,10 @@ class PHPExcel_Comment implements PHPExcel_IComparable
|
|||||||
public function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
// Initialise variables
|
// Initialise variables
|
||||||
$this->_author = 'Author';
|
$this->_author = 'Author';
|
||||||
$this->_text = new PHPExcel_RichText();
|
$this->_text = new PHPExcel_RichText();
|
||||||
$this->_fillColor = new PHPExcel_Style_Color('FFFFFFE1');
|
$this->_fillColor = new PHPExcel_Style_Color('FFFFFFE1');
|
||||||
$this->_alignment = PHPExcel_Style_Alignment::HORIZONTAL_GENERAL;
|
$this->_alignment = PHPExcel_Style_Alignment::HORIZONTAL_GENERAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -314,4 +314,9 @@ class PHPExcel_Comment implements PHPExcel_IComparable
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function __toString() {
|
||||||
|
return $this->_text->getPlainText();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -96,22 +96,176 @@ class PHPExcel_ReferenceHelper
|
|||||||
return ($ar < $br) ? 1 : -1;
|
return ($ar < $br) ? 1 : -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static function cellAddressInDeleteRange($cellAddress, $beforeRow, $pNumRows, $beforeColumnIndex, $pNumCols) {
|
||||||
|
list($cellColumn, $cellRow) = PHPExcel_Cell::coordinateFromString($cellAddress);
|
||||||
|
$cellColumnIndex = PHPExcel_Cell::columnIndexFromString($cellColumn);
|
||||||
|
// Is cell within the range of rows/columns if we're deleting
|
||||||
|
if ($pNumRows < 0 &&
|
||||||
|
($cellRow >= ($beforeRow + $pNumRows)) &&
|
||||||
|
($cellRow < $beforeRow)) {
|
||||||
|
return TRUE;
|
||||||
|
} elseif ($pNumCols < 0 &&
|
||||||
|
($cellColumnIndex >= ($beforeColumnIndex + $pNumCols)) &&
|
||||||
|
($cellColumnIndex < $beforeColumnIndex)) {
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function _adjustPageBreaks(PHPExcel_Worksheet $pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows)
|
||||||
|
{
|
||||||
|
$aBreaks = $pSheet->getBreaks();
|
||||||
|
($pNumCols > 0 || $pNumRows > 0) ?
|
||||||
|
uksort($aBreaks, array('PHPExcel_ReferenceHelper','cellReverseSort')) :
|
||||||
|
uksort($aBreaks, array('PHPExcel_ReferenceHelper','cellSort'));
|
||||||
|
|
||||||
|
foreach ($aBreaks as $key => $value) {
|
||||||
|
if (self::cellAddressInDeleteRange($key, $beforeRow, $pNumRows, $beforeColumnIndex, $pNumCols)) {
|
||||||
|
// If we're deleting, then clear any defined breaks that are within the range
|
||||||
|
// of rows/columns that we're deleting
|
||||||
|
$pSheet->setBreak($key, PHPExcel_Worksheet::BREAK_NONE);
|
||||||
|
} else {
|
||||||
|
// Otherwise update any affected breaks by inserting a new break at the appropriate point
|
||||||
|
// and removing the old affected break
|
||||||
|
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
||||||
|
if ($key != $newReference) {
|
||||||
|
$pSheet->setBreak($newReference, $value)
|
||||||
|
->setBreak($key, PHPExcel_Worksheet::BREAK_NONE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function _adjustComments($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows)
|
||||||
|
{
|
||||||
|
$aComments = $pSheet->getComments();
|
||||||
|
$aNewComments = array(); // the new array of all comments
|
||||||
|
|
||||||
|
foreach ($aComments as $key => &$value) {
|
||||||
|
// Any comments inside a deleted range will be ignored
|
||||||
|
if (!self::cellAddressInDeleteRange($key, $beforeRow, $pNumRows, $beforeColumnIndex, $pNumCols)) {
|
||||||
|
// Otherwise build a new array of comments indexed by the adjusted cell reference
|
||||||
|
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
||||||
|
$aNewComments[$newReference] = $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Replace the comments array with the new set of comments
|
||||||
|
$pSheet->setComments($aNewComments);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function _adjustHyperlinks($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows)
|
||||||
|
{
|
||||||
|
$aHyperlinkCollection = $pSheet->getHyperlinkCollection();
|
||||||
|
($pNumCols > 0 || $pNumRows > 0) ?
|
||||||
|
uksort($aHyperlinkCollection, array('PHPExcel_ReferenceHelper','cellReverseSort')) :
|
||||||
|
uksort($aHyperlinkCollection, array('PHPExcel_ReferenceHelper','cellSort'));
|
||||||
|
|
||||||
|
foreach ($aHyperlinkCollection as $key => $value) {
|
||||||
|
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
||||||
|
if ($key != $newReference) {
|
||||||
|
$pSheet->setHyperlink( $newReference, $value );
|
||||||
|
$pSheet->setHyperlink( $key, null );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function _adjustDataValidations($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows)
|
||||||
|
{
|
||||||
|
$aDataValidationCollection = $pSheet->getDataValidationCollection();
|
||||||
|
($pNumCols > 0 || $pNumRows > 0) ?
|
||||||
|
uksort($aDataValidationCollection, array('PHPExcel_ReferenceHelper','cellReverseSort')) :
|
||||||
|
uksort($aDataValidationCollection, array('PHPExcel_ReferenceHelper','cellSort'));
|
||||||
|
foreach ($aDataValidationCollection as $key => $value) {
|
||||||
|
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
||||||
|
if ($key != $newReference) {
|
||||||
|
$pSheet->setDataValidation( $newReference, $value );
|
||||||
|
$pSheet->setDataValidation( $key, null );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function _adjustMergeCells($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows)
|
||||||
|
{
|
||||||
|
$aMergeCells = $pSheet->getMergeCells();
|
||||||
|
$aNewMergeCells = array(); // the new array of all merge cells
|
||||||
|
foreach ($aMergeCells as $key => &$value) {
|
||||||
|
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
||||||
|
$aNewMergeCells[$newReference] = $newReference;
|
||||||
|
}
|
||||||
|
$pSheet->setMergeCells($aNewMergeCells); // replace the merge cells array
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function _adjustProtectedCells($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows)
|
||||||
|
{
|
||||||
|
$aProtectedCells = $pSheet->getProtectedCells();
|
||||||
|
($pNumCols > 0 || $pNumRows > 0) ?
|
||||||
|
uksort($aProtectedCells, array('PHPExcel_ReferenceHelper','cellReverseSort')) :
|
||||||
|
uksort($aProtectedCells, array('PHPExcel_ReferenceHelper','cellSort'));
|
||||||
|
foreach ($aProtectedCells as $key => $value) {
|
||||||
|
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
||||||
|
if ($key != $newReference) {
|
||||||
|
$pSheet->protectCells( $newReference, $value, true );
|
||||||
|
$pSheet->unprotectCells( $key );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function _adjustColumnDimensions($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows)
|
||||||
|
{
|
||||||
|
$aColumnDimensions = array_reverse($pSheet->getColumnDimensions(), true);
|
||||||
|
if (!empty($aColumnDimensions)) {
|
||||||
|
foreach ($aColumnDimensions as $objColumnDimension) {
|
||||||
|
$newReference = $this->updateCellReference($objColumnDimension->getColumnIndex() . '1', $pBefore, $pNumCols, $pNumRows);
|
||||||
|
list($newReference) = PHPExcel_Cell::coordinateFromString($newReference);
|
||||||
|
if ($objColumnDimension->getColumnIndex() != $newReference) {
|
||||||
|
$objColumnDimension->setColumnIndex($newReference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$pSheet->refreshColumnDimensions();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function _adjustRowDimensions($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows)
|
||||||
|
{
|
||||||
|
$aRowDimensions = array_reverse($pSheet->getRowDimensions(), true);
|
||||||
|
if (!empty($aRowDimensions)) {
|
||||||
|
foreach ($aRowDimensions as $objRowDimension) {
|
||||||
|
$newReference = $this->updateCellReference('A' . $objRowDimension->getRowIndex(), $pBefore, $pNumCols, $pNumRows);
|
||||||
|
list(, $newReference) = PHPExcel_Cell::coordinateFromString($newReference);
|
||||||
|
if ($objRowDimension->getRowIndex() != $newReference) {
|
||||||
|
$objRowDimension->setRowIndex($newReference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$pSheet->refreshRowDimensions();
|
||||||
|
|
||||||
|
$copyDimension = $pSheet->getRowDimension($beforeRow - 1);
|
||||||
|
for ($i = $beforeRow; $i <= $beforeRow - 1 + $pNumRows; ++$i) {
|
||||||
|
$newDimension = $pSheet->getRowDimension($i);
|
||||||
|
$newDimension->setRowHeight($copyDimension->getRowHeight());
|
||||||
|
$newDimension->setVisible($copyDimension->getVisible());
|
||||||
|
$newDimension->setOutlineLevel($copyDimension->getOutlineLevel());
|
||||||
|
$newDimension->setCollapsed($copyDimension->getCollapsed());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Insert a new column, updating all possible related data
|
* Insert a new column or row, updating all possible related data
|
||||||
*
|
*
|
||||||
* @param int $pBefore Insert before this one
|
* @param int $pBefore Insert before this one
|
||||||
* @param int $pNumCols Number of columns to insert
|
* @param int $pNumCols Number of columns to insert
|
||||||
* @param int $pNumRows Number of rows to insert
|
* @param int $pNumRows Number of rows to insert
|
||||||
* @throws PHPExcel_Exception
|
* @throws PHPExcel_Exception
|
||||||
*/
|
*/
|
||||||
public function insertNewBefore($pBefore = 'A1', $pNumCols = 0, $pNumRows = 0, PHPExcel_Worksheet $pSheet = null) {
|
public function insertNewBefore($pBefore = 'A1', $pNumCols = 0, $pNumRows = 0, PHPExcel_Worksheet $pSheet = NULL)
|
||||||
|
{
|
||||||
$remove = ($pNumCols < 0 || $pNumRows < 0);
|
$remove = ($pNumCols < 0 || $pNumRows < 0);
|
||||||
$aCellCollection = $pSheet->getCellCollection();
|
$aCellCollection = $pSheet->getCellCollection();
|
||||||
|
|
||||||
// Get coordinates of $pBefore
|
// Get coordinates of $pBefore
|
||||||
$beforeColumn = 'A';
|
$beforeColumn = 'A';
|
||||||
$beforeRow = 1;
|
$beforeRow = 1;
|
||||||
list($beforeColumn, $beforeRow) = PHPExcel_Cell::coordinateFromString( $pBefore );
|
list($beforeColumn, $beforeRow) = PHPExcel_Cell::coordinateFromString($pBefore);
|
||||||
$beforeColumnIndex = PHPExcel_Cell::columnIndexFromString($beforeColumn);
|
$beforeColumnIndex = PHPExcel_Cell::columnIndexFromString($beforeColumn);
|
||||||
|
|
||||||
// Clear cells if we are removing columns or rows
|
// Clear cells if we are removing columns or rows
|
||||||
@ -242,109 +396,28 @@ class PHPExcel_ReferenceHelper
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Update worksheet: column dimensions
|
// Update worksheet: column dimensions
|
||||||
$aColumnDimensions = array_reverse($pSheet->getColumnDimensions(), true);
|
$this->_adjustColumnDimensions($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows);
|
||||||
if (!empty($aColumnDimensions)) {
|
|
||||||
foreach ($aColumnDimensions as $objColumnDimension) {
|
|
||||||
$newReference = $this->updateCellReference($objColumnDimension->getColumnIndex() . '1', $pBefore, $pNumCols, $pNumRows);
|
|
||||||
list($newReference) = PHPExcel_Cell::coordinateFromString($newReference);
|
|
||||||
if ($objColumnDimension->getColumnIndex() != $newReference) {
|
|
||||||
$objColumnDimension->setColumnIndex($newReference);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$pSheet->refreshColumnDimensions();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update worksheet: row dimensions
|
// Update worksheet: row dimensions
|
||||||
$aRowDimensions = array_reverse($pSheet->getRowDimensions(), true);
|
$this->_adjustRowDimensions($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows);
|
||||||
if (!empty($aRowDimensions)) {
|
|
||||||
foreach ($aRowDimensions as $objRowDimension) {
|
|
||||||
$newReference = $this->updateCellReference('A' . $objRowDimension->getRowIndex(), $pBefore, $pNumCols, $pNumRows);
|
|
||||||
list(, $newReference) = PHPExcel_Cell::coordinateFromString($newReference);
|
|
||||||
if ($objRowDimension->getRowIndex() != $newReference) {
|
|
||||||
$objRowDimension->setRowIndex($newReference);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$pSheet->refreshRowDimensions();
|
|
||||||
|
|
||||||
$copyDimension = $pSheet->getRowDimension($beforeRow - 1);
|
// Update worksheet: page breaks
|
||||||
for ($i = $beforeRow; $i <= $beforeRow - 1 + $pNumRows; ++$i) {
|
$this->_adjustPageBreaks($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows);
|
||||||
$newDimension = $pSheet->getRowDimension($i);
|
|
||||||
$newDimension->setRowHeight($copyDimension->getRowHeight());
|
|
||||||
$newDimension->setVisible($copyDimension->getVisible());
|
|
||||||
$newDimension->setOutlineLevel($copyDimension->getOutlineLevel());
|
|
||||||
$newDimension->setCollapsed($copyDimension->getCollapsed());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update worksheet: breaks
|
// Update worksheet: comments
|
||||||
$aBreaks = $pSheet->getBreaks();
|
$this->_adjustComments($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows);
|
||||||
($pNumCols > 0 || $pNumRows > 0) ?
|
|
||||||
uksort($aBreaks, array('PHPExcel_ReferenceHelper','cellReverseSort')) :
|
|
||||||
uksort($aBreaks, array('PHPExcel_ReferenceHelper','cellSort'));
|
|
||||||
foreach ($aBreaks as $key => $value) {
|
|
||||||
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
|
||||||
if ($key != $newReference) {
|
|
||||||
$pSheet->setBreak($newReference, $value)
|
|
||||||
->setBreak($key, PHPExcel_Worksheet::BREAK_NONE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update worksheet: comments
|
|
||||||
$aComments = $pSheet->getComments();
|
|
||||||
$aNewComments = array(); // the new array of all comments
|
|
||||||
foreach ($aComments as $key => &$value) {
|
|
||||||
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
|
||||||
$aNewComments[$newReference] = $value;
|
|
||||||
}
|
|
||||||
$pSheet->setComments($aNewComments); // replace the comments array
|
|
||||||
|
|
||||||
// Update worksheet: hyperlinks
|
// Update worksheet: hyperlinks
|
||||||
$aHyperlinkCollection = $pSheet->getHyperlinkCollection();
|
$this->_adjustHyperlinks($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows);
|
||||||
($pNumCols > 0 || $pNumRows > 0) ?
|
|
||||||
uksort($aHyperlinkCollection, array('PHPExcel_ReferenceHelper','cellReverseSort')) :
|
|
||||||
uksort($aHyperlinkCollection, array('PHPExcel_ReferenceHelper','cellSort'));
|
|
||||||
foreach ($aHyperlinkCollection as $key => $value) {
|
|
||||||
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
|
||||||
if ($key != $newReference) {
|
|
||||||
$pSheet->setHyperlink( $newReference, $value );
|
|
||||||
$pSheet->setHyperlink( $key, null );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update worksheet: data validations
|
// Update worksheet: data validations
|
||||||
$aDataValidationCollection = $pSheet->getDataValidationCollection();
|
$this->_adjustDataValidations($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows);
|
||||||
($pNumCols > 0 || $pNumRows > 0) ?
|
|
||||||
uksort($aDataValidationCollection, array('PHPExcel_ReferenceHelper','cellReverseSort')) :
|
|
||||||
uksort($aDataValidationCollection, array('PHPExcel_ReferenceHelper','cellSort'));
|
|
||||||
foreach ($aDataValidationCollection as $key => $value) {
|
|
||||||
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
|
||||||
if ($key != $newReference) {
|
|
||||||
$pSheet->setDataValidation( $newReference, $value );
|
|
||||||
$pSheet->setDataValidation( $key, null );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update worksheet: merge cells
|
// Update worksheet: merge cells
|
||||||
$aMergeCells = $pSheet->getMergeCells();
|
$this->_adjustMergeCells($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows);
|
||||||
$aNewMergeCells = array(); // the new array of all merge cells
|
|
||||||
foreach ($aMergeCells as $key => &$value) {
|
|
||||||
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
|
||||||
$aNewMergeCells[$newReference] = $newReference;
|
|
||||||
}
|
|
||||||
$pSheet->setMergeCells($aNewMergeCells); // replace the merge cells array
|
|
||||||
|
|
||||||
// Update worksheet: protected cells
|
// Update worksheet: protected cells
|
||||||
$aProtectedCells = $pSheet->getProtectedCells();
|
$this->_adjustProtectedCells($pSheet, $pBefore, $beforeColumnIndex, $pNumCols, $beforeRow, $pNumRows);
|
||||||
($pNumCols > 0 || $pNumRows > 0) ?
|
|
||||||
uksort($aProtectedCells, array('PHPExcel_ReferenceHelper','cellReverseSort')) :
|
|
||||||
uksort($aProtectedCells, array('PHPExcel_ReferenceHelper','cellSort'));
|
|
||||||
foreach ($aProtectedCells as $key => $value) {
|
|
||||||
$newReference = $this->updateCellReference($key, $pBefore, $pNumCols, $pNumRows);
|
|
||||||
if ($key != $newReference) {
|
|
||||||
$pSheet->protectCells( $newReference, $value, true );
|
|
||||||
$pSheet->unprotectCells( $key );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update worksheet: autofilter
|
// Update worksheet: autofilter
|
||||||
$autoFilter = $pSheet->getAutoFilter();
|
$autoFilter = $pSheet->getAutoFilter();
|
||||||
|
58
unitTests/Classes/PHPExcel/ReferenceHelperTest.php
Normal file
58
unitTests/Classes/PHPExcel/ReferenceHelperTest.php
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
class ReferenceHelperTest extends PHPUnit_Framework_TestCase
|
||||||
|
{
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
if (!defined('PHPEXCEL_ROOT')) {
|
||||||
|
define('PHPEXCEL_ROOT', APPLICATION_PATH . '/');
|
||||||
|
}
|
||||||
|
require_once(PHPEXCEL_ROOT . 'PHPExcel/Autoloader.php');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testColumnSort()
|
||||||
|
{
|
||||||
|
$columnBase = $columnExpectedResult = array(
|
||||||
|
'A','B','Z',
|
||||||
|
'AA','AB','AZ',
|
||||||
|
'BA','BB','BZ',
|
||||||
|
'ZA','ZB','ZZ',
|
||||||
|
'AAA','AAB','AAZ',
|
||||||
|
'ABA','ABB','ABZ',
|
||||||
|
'AZA','AZB','AZZ',
|
||||||
|
'BAA','BAB','BAZ',
|
||||||
|
'BBA','BBB','BBZ',
|
||||||
|
'BZA','BZB','BZZ'
|
||||||
|
);
|
||||||
|
shuffle($columnBase);
|
||||||
|
usort($columnBase, array('PHPExcel_ReferenceHelper','columnSort'));
|
||||||
|
foreach($columnBase as $key => $value) {
|
||||||
|
$this->assertEquals($columnExpectedResult[$key], $value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testColumnReverseSort()
|
||||||
|
{
|
||||||
|
$columnBase = $columnExpectedResult = array(
|
||||||
|
'A','B','Z',
|
||||||
|
'AA','AB','AZ',
|
||||||
|
'BA','BB','BZ',
|
||||||
|
'ZA','ZB','ZZ',
|
||||||
|
'AAA','AAB','AAZ',
|
||||||
|
'ABA','ABB','ABZ',
|
||||||
|
'AZA','AZB','AZZ',
|
||||||
|
'BAA','BAB','BAZ',
|
||||||
|
'BBA','BBB','BBZ',
|
||||||
|
'BZA','BZB','BZZ'
|
||||||
|
);
|
||||||
|
shuffle($columnBase);
|
||||||
|
$columnExpectedResult = array_reverse($columnExpectedResult);
|
||||||
|
usort($columnBase, array('PHPExcel_ReferenceHelper','columnReverseSort'));
|
||||||
|
foreach($columnBase as $key => $value) {
|
||||||
|
$this->assertEquals($columnExpectedResult[$key], $value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user