swa*_*esh 5 php loops phpexcel
我已经使用PHPExcel按行和列一起检查了Excel中的这个合并单元格,但它仅显示行添加,但是我也对列应用了一些测试,但没有一个正在工作.
此代码虽然成功创建了excel表,但excel中的输出却抛出了错误.
编辑
但是如果删除了llop并且用简单的术语表示这是有用的 -
$objPHPExcel->setActiveSheetIndex(0)->mergeCells('A1:B1');
$objPHPExcel->getActiveSheet()->setCellValue('A1', 'Swapnesh');
Run Code Online (Sandbox Code Playgroud)
添加数据的主要代码 -
// Add some data
echo date('H:i:s') , " Add some data" , EOL;
$i = "A";
$j ="B";
for($num =1; $num <= 5; $num++ )
{
$concat = "{$i}1:{$j}1";
$objPHPExcel->setActiveSheetIndex(0)->mergeCells($concat);
$i++;$j++;
}
$objPHPExcel->getActiveSheet()->setCellValue('A1', 'Swapnesh');
Run Code Online (Sandbox Code Playgroud)
我的整个代码 -
<?php
error_reporting(E_ALL);
ini_set('display_errors', TRUE);
ini_set('display_startup_errors', TRUE);
define('EOL',(PHP_SAPI == 'cli') ? PHP_EOL : '<br />');
date_default_timezone_set('Asia/Calcutta');
/** Include PHPExcel */
require_once 'Classes/PHPExcel.php';
// Create new PHPExcel object
echo date('H:i:s') , " Create new PHPExcel object" , EOL;
$objPHPExcel = new PHPExcel();
// Set document properties
echo date('H:i:s') , " Set document properties" , EOL;
$objPHPExcel->
getProperties()->setCreator("Swapnesh Sinha")
->setLastModifiedBy("Swapnesh")
->setTitle("Office 2007 XLSX Test Document")
->setSubject("Office 2007 XLSX Test Document")
->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")
->setKeywords("office 2007 openxml php")
->setCategory("Test result file");
// Add some data
echo date('H:i:s') , " Add some data" , EOL;
$i = "A";
$j ="B";
for($num =1; $num <= 5; $num++ )
{
$concat = "{$i}1:{$j}1";
$objPHPExcel->setActiveSheetIndex(0)->mergeCells($concat);
$i++;$j++;
}
$objPHPExcel->getActiveSheet()->setCellValue('A1', 'Swapnesh');
// Rename worksheet
echo date('H:i:s') , " Rename worksheet" , EOL;
$objPHPExcel->getActiveSheet()->setTitle('Student Data');
// Set document security
echo date('H:i:s') , " Set document security" , EOL;
$objPHPExcel->getSecurity()->setLockWindows(true);
$objPHPExcel->getSecurity()->setLockStructure(true);
$objPHPExcel->getSecurity()->setWorkbookPassword("PHPExcel");
// Set sheet security
echo date('H:i:s') , " Set sheet security" , EOL;
$objPHPExcel->getActiveSheet()->getProtection()->setPassword('PHPExcel');
$objPHPExcel->getActiveSheet()->getProtection()->setSheet(true); // This should be enabled in order to enable any of the following!
$objPHPExcel->getActiveSheet()->getProtection()->setSort(true);
$objPHPExcel->getActiveSheet()->getProtection()->setInsertRows(true);
$objPHPExcel->getActiveSheet()->getProtection()->setFormatCells(true);
// Set active sheet index to the first sheet, so Excel opens this as the first sheet
$objPHPExcel->setActiveSheetIndex(0);
// Save Excel 2007 file
echo date('H:i:s') , " Write to Excel2007 format" , EOL;
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
//$objWriter->save(str_replace('.php', '.xlsx', __FILE__));
$filename = "Student-data-sheet".".xlsx";
$objWriter->save($filename);
echo date('H:i:s') , " File written to " , str_replace('.php', '.xlsx', pathinfo(__FILE__, PATHINFO_BASENAME)) , EOL;
// Echo memory peak usage
echo date('H:i:s') , " Peak memory usage: " , (memory_get_peak_usage(true) / 1024 / 1024) , " MB" , EOL;
// Echo done
echo date('H:i:s') , " Done writing file" , EOL;
echo 'File has been created in ' , getcwd() , EOL;
Run Code Online (Sandbox Code Playgroud)
swa*_*esh 12
我自己找出解决方案 -
实际上在列合并的情况下,我们实际上不需要迭代.让我们说我想从列合并A1到E1.
因此,不是逐个循环,而是可以通过以下方式轻松完成:
$objPHPExcel->setActiveSheetIndex(0)->mergeCells('A1:E1');
Run Code Online (Sandbox Code Playgroud)
所以在我的情况下,我首先需要找到最后一个元素和第一个元素,然后简单地放入mergeCells()方法使其工作.
小智 5
当您尝试合并两个单元格循环时,会发生此问题.原因不是您正在迭代的循环,而是您传递的列名称.如果您传递错误的列名,那么您的Excel将无法生成正确的输出.
以下是获取下一个excel专栏的简单程序,以便我们不会遇到这样的问题.
/* manage excel index */
function getColumn($prevColumn){
if(strlen($prevColumn)==1&&$prevColumn!="Z")
{ $prevColumn++;return $prevColumn; }
$colum = '';
$list = str_split($prevColumn);
if(count($list)==1&&$list[0]=='Z')
{
$list[0] = "A";
$list[1] = "A";
}
else if(count($list)==2&&$list[1]!='Z')
{
$list[1]++;
}
else if(count($list)==2&&$list[1]=='Z')
{
$list[0] = "B";
$list[1] = "A";
}
return implode('',$list);
}
## us this like below
$column = "A";
$row = 1;
foreach($array_to_print as $details)
{
$column = getColumn($column); // product next column B
$Excelobj->getActiveSheet()->setCellValue($column.$row, $details);
$column = getColumn($column);// product next column C
$Excelobj->setActiveSheetIndex(0)->mergeCells($from_cell.':'.$to_cell);// now this will work till A-ZZ column in excel
}
Run Code Online (Sandbox Code Playgroud)