phpexcel读取合并单元格的值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了phpexcel读取合并单元格的值相关的知识,希望对你有一定的参考价值。

include_once 'phpExcel/Classes/PHPExcel/IOFactory.php';
$loadfile=$uploadfile_xls;
if (!file_exists($loadfile))
exit("Please run 05featuredemo.php first.\n");


$objReader = PHPExcel_IOFactory::createReader('Excel5');

$objPHPExcel = $objReader->load($loadfile);

$sheet = $objPHPExcel->getSheet(0); // 读取第一个工作表(编号从 0 开始)
$highestRow = $sheet->getHighestRow(); // 取得总列数

for ($row = 2; $row <= $highestRow; $row++)

$xx=$sheet->getCell("A$row")->getValue();

if(empty($xx))
$xx="无";
else
$xx=iconv('utf-8','gbk',$xx);

echo $xx;
echo "<br>============<br>";
$num = $sheet->getCellByColumnAndRow(5, $row)->getValue();
$content = $sheet->getCellByColumnAndRow(6, $row)->getValue();
//
$theme = $sheet->getCellByColumnAndRow(0, $row)->getValue();

$num=iconv('utf-8','gbk',$num);
$content=iconv('utf-8','gbk',$content);
//
$theme=iconv('utf-8','gbk',$theme);

if($num && $content)
$arr=array("pid"=>$pid,"content"=>$content,"num"=>$num,"theme"=>$theme);
//insertxintable("requirement_detail",$arr);

$show_arr[]=$arr;


unset($objPHPExcel);


输出:
大年初二的春节祝福
============

============

============

============

============

============

============

怎么让获取的都是 “大年初二的春节祝福”?

实在不行的话,程序控制,如果为空,值为向上最靠近的那个?怎么控制一下?

总结 php导出Excel php导入Excel PhpExcel使用说明 PhpExcel使用手册2009/03/06 上午 02:37方法一:特点,简单,省心,

<?php
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=test_data.xls");

$tx='表头';
echo $tx."\n\n";
//输出内容如下:
echo "姓名"."\t";
echo "年龄"."\t";
echo "学历"."\t";
echo "\n";
echo "张三"."\t";
echo "25"."\t";
echo "本科"."\t";
?>

方法二: 引用google code中推荐的小类库(大体同方法一,比较复杂点)

方法三: PHPEXCEL 类库,功能强大,支持win Excel2003 ,Win Excel2007.

<?
//设置PHPExcel类库的include path
set_include_path('.'. PATH_SEPARATOR .
'D:\Zeal\PHP_LIBS' . PATH_SEPARATOR .
get_include_path());

/**
* 以下是使用示例,对于以 //// 开头的行是不同的可选方式,请根据实际需要
* 打开对应行的注释。
* 如果使用 Excel5 ,输出的内容应该是GBK编码。
*/
require_once 'PHPExcel.php';

// uncomment
////require_once 'PHPExcel/Writer/Excel5.php'; // 用于其他低版本xls
// or
////require_once 'PHPExcel/Writer/Excel2007.php'; // 用于 excel-2007 格式

// 创建一个处理对象实例
$objExcel = new PHPExcel();

// 创建文件格式写入对象实例, uncomment
////$objWriter = new PHPExcel_Writer_Excel5($objExcel); // 用于其他版本格式
// or
////$objWriter = new PHPExcel_Writer_Excel2007($objExcel); // 用于 2007 格式
//$objWriter->setOffice2003Compatibility(true);

//*************************************
//设置文档基本属性
$objProps = $objExcel->getProperties();
$objProps->setCreator("Zeal Li");
$objProps->setLastModifiedBy("Zeal Li");
$objProps->setTitle("Office XLS Test Document");
$objProps->setSubject("Office XLS Test Document, Demo");
$objProps->setDescription("Test document, generated by PHPExcel.");
$objProps->setKeywords("office excel PHPExcel");
$objProps->setCategory("Test");

//*************************************
//设置当前的sheet索引,用于后续的内容操作。
//一般只有在使用多个sheet的时候才需要显示调用。
//缺省情况下,PHPExcel会自动创建第一个sheet被设置SheetIndex=0
$objExcel->setActiveSheetIndex(0);

$objActSheet = $objExcel->getActiveSheet();

//设置当前活动sheet的名称
$objActSheet->setTitle('测试Sheet');

//*************************************
//设置单元格内容
//
//由PHPExcel根据传入内容自动判断单元格内容类型
$objActSheet->setCellValue('A1', '字符串内容'); // 字符串内容
$objActSheet->setCellValue('A2', 26); // 数值
$objActSheet->setCellValue('A3', true); // 布尔值
$objActSheet->setCellValue('A4', '=SUM(A2:A2)'); // 公式

//显式指定内容类型
$objActSheet->setCellValueExplicit('A5', '847475847857487584',
PHPExcel_Cell_DataType::TYPE_STRING);

//合并单元格
$objActSheet->mergeCells('B1:C22');

//分离单元格
$objActSheet->unmergeCells('B1:C22');

//*************************************
//设置单元格样式
//

//设置宽度
$objActSheet->getColumnDimension('B')->setAutoSize(true);
$objActSheet->getColumnDimension('A')->setWidth(30);

$objStyleA5 = $objActSheet->getStyle('A5');

//设置单元格内容的数字格式。
//
//如果使用了 PHPExcel_Writer_Excel5 来生成内容的话,
//这里需要注意,在 PHPExcel_Style_NumberFormat 类的 const 变量定义的
//各种自定义格式化方式中,其它类型都可以正常使用,但当setFormatCode
//为 FORMAT_NUMBER 的时候,实际出来的效果被没有把格式设置为"0"。需要
//修改 PHPExcel_Writer_Excel5_Format 类源代码中的 getXf($style) 方法,
//在 if ($this->_BIFF_version == 0x0500) (第363行附近)前面增加一
参考技术A 整理数组 让数组的值为上一个不是空的本回答被提问者采纳

如何获取合并单元格的值?

【中文标题】如何获取合并单元格的值?【英文标题】:How to get the value of a merged cell? 【发布时间】:2011-07-02 05:20:46 【问题描述】:

我正在做一个项目,该项目必须从几个 Excel 文件制作 pdf 报告。文件应如下所示:http://img194.imageshack.us/i/24766860.jpg/ 和 pdf 应如下所示:http://img96.imageshack.us/i/u2ntitled.jpg/ 其中位置列必须具有 excel 文件中合并单元格的值 (B2:E2)。

所以难点在于如何读取合并后的单元格并将其值放入位置列。

如果这些信息还不够,我可以添加源代码。如果您需要任何其他信息,请询问我会立即提供。

【问题讨论】:

如果回答了您的问题,请不要忘记标记答案:) 【参考方案1】:

excel 中合并的单元格通过它们的第一个单元格地址读取。您应该能够将合并的单元格 B2:E2 选为 B2

【讨论】:

以上是关于phpexcel读取合并单元格的值的主要内容,如果未能解决你的问题,请参考以下文章

java poi怎么读取Excel中合并单元格的值?

nodejs读取excel时如何判断合并的单元格

vc++ 读取excel多个单元格的问题

php 数据导出到excel 2种带有合并单元格的导出

如何保持每个单元格中合并单元格的值?

有关java通过poi处理excle中合并单元格的问题