当前位置: 首页>>代码示例>>PHP>>正文


PHP PHPExcel_Cell::buildRange方法代码示例

本文整理汇总了PHP中PHPExcel_Cell::buildRange方法的典型用法代码示例。如果您正苦于以下问题:PHP PHPExcel_Cell::buildRange方法的具体用法?PHP PHPExcel_Cell::buildRange怎么用?PHP PHPExcel_Cell::buildRange使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在PHPExcel_Cell的用法示例。


在下文中一共展示了PHPExcel_Cell::buildRange方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: _writeDefinedNameForNamedRange

 /**
  * Write Defined Name for named range
  *
  * @param 	PHPExcel_Shared_XMLWriter	$objWriter 		XML Writer
  * @param 	PHPExcel_NamedRange			$pNamedRange
  * @throws 	PHPExcel_Writer_Exception
  */
 private function _writeDefinedNameForNamedRange(PHPExcel_Shared_XMLWriter $objWriter = null, PHPExcel_NamedRange $pNamedRange)
 {
     // definedName for named range
     $objWriter->startElement('definedName');
     $objWriter->writeAttribute('name', $pNamedRange->getName());
     if ($pNamedRange->getLocalOnly()) {
         $objWriter->writeAttribute('localSheetId', $pNamedRange->getScope()->getParent()->getIndex($pNamedRange->getScope()));
     }
     // Create absolute coordinate and write as raw text
     $range = PHPExcel_Cell::splitRange($pNamedRange->getRange());
     for ($i = 0; $i < count($range); $i++) {
         $range[$i][0] = '\'' . str_replace("'", "''", $pNamedRange->getWorksheet()->getTitle()) . '\'!' . PHPExcel_Cell::absoluteReference($range[$i][0]);
         if (isset($range[$i][1])) {
             $range[$i][1] = PHPExcel_Cell::absoluteReference($range[$i][1]);
         }
     }
     $range = PHPExcel_Cell::buildRange($range);
     $objWriter->writeRawData($range);
     $objWriter->endElement();
 }
开发者ID:Princelo,项目名称:bioerp,代码行数:27,代码来源:Workbook.php

示例2: _updateCellRange

 /**
  * Update cell range
  *
  * @param	string	$pCellRange			Cell range
  * @param	int		$pBefore			Insert before this one
  * @param	int		$pNumCols			Number of columns to increment
  * @param	int		$pNumRows			Number of rows to increment
  * @return	string	Updated cell range
  * @throws	Exception
  */
 private function _updateCellRange($pCellRange = 'A1:A1', $pBefore = 'A1', $pNumCols = 0, $pNumRows = 0)
 {
     if (strpos($pCellRange, ':') !== false || strpos($pCellRange, ',') !== false) {
         // Update range
         $range = PHPExcel_Cell::splitRange($pCellRange);
         for ($i = 0; $i < count($range); ++$i) {
             for ($j = 0; $j < count($range[$i]); ++$j) {
                 $range[$i][$j] = $this->_updateSingleCellReference($range[$i][$j], $pBefore, $pNumCols, $pNumRows);
             }
         }
         // Recreate range string
         return PHPExcel_Cell::buildRange($range);
     } else {
         throw new Exception("Only cell ranges may be passed to this method.");
     }
 }
开发者ID:honj51,项目名称:taobaocrm,代码行数:26,代码来源:ReferenceHelper.php

示例3: writeAllDefinedNamesBiff8

 /**
  * Writes all the DEFINEDNAME records (BIFF8).
  * So far this is only used for repeating rows/columns (print titles) and print areas
  */
 private function writeAllDefinedNamesBiff8()
 {
     $chunk = '';
     // Named ranges
     if (count($this->phpExcel->getNamedRanges()) > 0) {
         // Loop named ranges
         $namedRanges = $this->phpExcel->getNamedRanges();
         foreach ($namedRanges as $namedRange) {
             // Create absolute coordinate
             $range = PHPExcel_Cell::splitRange($namedRange->getRange());
             for ($i = 0; $i < count($range); $i++) {
                 $range[$i][0] = '\'' . str_replace("'", "''", $namedRange->getWorksheet()->getTitle()) . '\'!' . PHPExcel_Cell::absoluteCoordinate($range[$i][0]);
                 if (isset($range[$i][1])) {
                     $range[$i][1] = PHPExcel_Cell::absoluteCoordinate($range[$i][1]);
                 }
             }
             $range = PHPExcel_Cell::buildRange($range);
             // e.g. Sheet1!$A$1:$B$2
             // parse formula
             try {
                 $error = $this->parser->parse($range);
                 $formulaData = $this->parser->toReversePolish();
                 // make sure tRef3d is of type tRef3dR (0x3A)
                 if (isset($formulaData[0]) and ($formulaData[0] == "z" or $formulaData[0] == "Z")) {
                     $formulaData = ":" . substr($formulaData, 1);
                 }
                 if ($namedRange->getLocalOnly()) {
                     // local scope
                     $scope = $this->phpExcel->getIndex($namedRange->getScope()) + 1;
                 } else {
                     // global scope
                     $scope = 0;
                 }
                 $chunk .= $this->writeData($this->writeDefinedNameBiff8($namedRange->getName(), $formulaData, $scope, false));
             } catch (PHPExcel_Exception $e) {
                 // do nothing
             }
         }
     }
     // total number of sheets
     $total_worksheets = $this->phpExcel->getSheetCount();
     // write the print titles (repeating rows, columns), if any
     for ($i = 0; $i < $total_worksheets; ++$i) {
         $sheetSetup = $this->phpExcel->getSheet($i)->getPageSetup();
         // simultaneous repeatColumns repeatRows
         if ($sheetSetup->isColumnsToRepeatAtLeftSet() && $sheetSetup->isRowsToRepeatAtTopSet()) {
             $repeat = $sheetSetup->getColumnsToRepeatAtLeft();
             $colmin = PHPExcel_Cell::columnIndexFromString($repeat[0]) - 1;
             $colmax = PHPExcel_Cell::columnIndexFromString($repeat[1]) - 1;
             $repeat = $sheetSetup->getRowsToRepeatAtTop();
             $rowmin = $repeat[0] - 1;
             $rowmax = $repeat[1] - 1;
             // construct formula data manually
             $formulaData = pack('Cv', 0x29, 0x17);
             // tMemFunc
             $formulaData .= pack('Cvvvvv', 0x3b, $i, 0, 65535, $colmin, $colmax);
             // tArea3d
             $formulaData .= pack('Cvvvvv', 0x3b, $i, $rowmin, $rowmax, 0, 255);
             // tArea3d
             $formulaData .= pack('C', 0x10);
             // tList
             // store the DEFINEDNAME record
             $chunk .= $this->writeData($this->writeDefinedNameBiff8(pack('C', 0x7), $formulaData, $i + 1, true));
             // (exclusive) either repeatColumns or repeatRows
         } elseif ($sheetSetup->isColumnsToRepeatAtLeftSet() || $sheetSetup->isRowsToRepeatAtTopSet()) {
             // Columns to repeat
             if ($sheetSetup->isColumnsToRepeatAtLeftSet()) {
                 $repeat = $sheetSetup->getColumnsToRepeatAtLeft();
                 $colmin = PHPExcel_Cell::columnIndexFromString($repeat[0]) - 1;
                 $colmax = PHPExcel_Cell::columnIndexFromString($repeat[1]) - 1;
             } else {
                 $colmin = 0;
                 $colmax = 255;
             }
             // Rows to repeat
             if ($sheetSetup->isRowsToRepeatAtTopSet()) {
                 $repeat = $sheetSetup->getRowsToRepeatAtTop();
                 $rowmin = $repeat[0] - 1;
                 $rowmax = $repeat[1] - 1;
             } else {
                 $rowmin = 0;
                 $rowmax = 65535;
             }
             // construct formula data manually because parser does not recognize absolute 3d cell references
             $formulaData = pack('Cvvvvv', 0x3b, $i, $rowmin, $rowmax, $colmin, $colmax);
             // store the DEFINEDNAME record
             $chunk .= $this->writeData($this->writeDefinedNameBiff8(pack('C', 0x7), $formulaData, $i + 1, true));
         }
     }
     // write the print areas, if any
     for ($i = 0; $i < $total_worksheets; ++$i) {
         $sheetSetup = $this->phpExcel->getSheet($i)->getPageSetup();
         if ($sheetSetup->isPrintAreaSet()) {
             // Print area, e.g. A3:J6,H1:X20
             $printArea = PHPExcel_Cell::splitRange($sheetSetup->getPrintArea());
             $countPrintArea = count($printArea);
//.........这里部分代码省略.........
开发者ID:jaya-project,项目名称:zycms,代码行数:101,代码来源:Workbook.php

示例4: _updateCellRange

 /**
  * Update cell range
  *
  * @param	string	$pCellRange			Cell range	(e.g. 'B2:D4', 'B:C' or '2:3')
  * @param	int		$pBefore			Insert before this one
  * @param	int		$pNumCols			Number of columns to increment
  * @param	int		$pNumRows			Number of rows to increment
  * @return	string	Updated cell range
  * @throws	PHPExcel_Exception
  */
 private function _updateCellRange($pCellRange = 'A1:A1', $pBefore = 'A1', $pNumCols = 0, $pNumRows = 0)
 {
     if (strpos($pCellRange, ':') !== false || strpos($pCellRange, ',') !== false) {
         // Update range
         $range = PHPExcel_Cell::splitRange($pCellRange);
         $ic = count($range);
         for ($i = 0; $i < $ic; ++$i) {
             $jc = count($range[$i]);
             for ($j = 0; $j < $jc; ++$j) {
                 if (ctype_alpha($range[$i][$j])) {
                     $r = PHPExcel_Cell::coordinateFromString($this->_updateSingleCellReference($range[$i][$j] . '1', $pBefore, $pNumCols, $pNumRows));
                     $range[$i][$j] = $r[0];
                 } elseif (ctype_digit($range[$i][$j])) {
                     $r = PHPExcel_Cell::coordinateFromString($this->_updateSingleCellReference('A' . $range[$i][$j], $pBefore, $pNumCols, $pNumRows));
                     $range[$i][$j] = $r[1];
                 } else {
                     $range[$i][$j] = $this->_updateSingleCellReference($range[$i][$j], $pBefore, $pNumCols, $pNumRows);
                 }
             }
         }
         // Recreate range string
         return PHPExcel_Cell::buildRange($range);
     } else {
         throw new PHPExcel_Exception("Only cell ranges may be passed to this method.");
     }
 }
开发者ID:ljhchshm,项目名称:weixin,代码行数:36,代码来源:ReferenceHelper.php

示例5: array

 $xlWS->getDefaultColumnDimension()->setWidth(-1);
 // Titre
 $range = 'A1';
 $style = array('font' => array('bold' => true, 'size' => 20));
 $xlWS->setCellValue($range, $classe_fullname . ' - école de ' . $classe_ecole)->mergeCells($range . ':' . $last_col . 1)->getStyle($range)->applyFromArray($style);
 $xlWS->getRowDimension(1)->setRowHeight(25);
 // Teachers
 $qryProfs->execute(array($classe_id));
 $profs = $qryProfs->fetchAll();
 $row = 3;
 $col = 0;
 $xlWS->setCellValueByColumnAndRow($col++, $row, 'Titulaire' . (count($profs) == 1 ? '' : 's'));
 foreach ($profs as $prof) {
     extract($prof, EXTR_PREFIX_ALL, 'prof');
     $xlWS->setCellValueByColumnAndRow($col, $row, $prof_nom);
     $xlWS->mergeCells(PHPExcel_Cell::buildRange(array(array(PHPExcel_Cell::stringFromColumnIndex($col) . $row, PHPExcel_Cell::stringFromColumnIndex($col + 2) . $row))));
     // Do not display teachers' e-mail address, as per instructions from
     // P.-C. Dagau 20150915 since not all teachers are using it to
     // communicate with parents
     //		if(!empty($prof_email)) {
     //			process_email(COL_EMAIL . $row, $prof_email);
     //		}
     $row++;
 }
 // Class size
 $row++;
 $col = 0;
 $xlWS->setCellValueByColumnAndRow($col++, $row, 'Effectif');
 $xlWS->setCellValueByColumnAndRow($col, $row, $count)->getStyleByColumnAndRow($col++, $row)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_LEFT);
 $col++;
 $xlWS->setCellValueByColumnAndRow($col++, $row, 'Prévu à la rentrée');
开发者ID:dregad,项目名称:apecove,代码行数:31,代码来源:export_classes.php


注:本文中的PHPExcel_Cell::buildRange方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。