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
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读取合并单元格的值的主要内容,如果未能解决你的问题,请参考以下文章