phpexcel读取excel文件实例与知识点

发布时间:2019-11-06编辑:脚本学堂
本文介绍了phpexcel读取excel 2007 或excel2003文件的方法,phpexcel类库读取文件的例子,需要的朋友参考下。

例子,phpexcel读取excel文件。

知识点:
1,php对excel文件进行循环读取。
2,php对字符进行ascii编码转化,将字符转为十进制数。
3,php对excel日期格式读取,并进行显示转化。
4,php对汉字乱码进行编码转化。

phpexcel类库官网地址:http://phpexcel.codeplex.com/

对phpexcel类库不熟悉的朋友,可以阅读下《phpexcel中文帮助手册》中的内容,具体实例大家可以phpexcel快速开发指南中的相关例子。

完整代码:
 

复制代码 代码示例:

<?php
require_once 'phpexcel.php';

/**对excel里的日期进行格式转化*/
function getdata($val){
$jd = gregoriantojd(1, 1, 1970);
$gregorian = jdtogregorian($jd+intval($val)-25569);
return $gregorian;/**显示格式为 “月/日/年” */
}

$filepath = 'test.xlsx';
$phpexcel = new phpexcel();

/**默认用excel2007读取excel,若格式不对,则用之前的版本进行读取*/
$phpreader = new phpexcel_reader_excel2007();
if(!$phpreader->canread($filepath)){
$phpreader = new phpexcel_reader_excel5();
if(!$phpreader->canread($filepath)){
echo 'no excel';
return ;
}
}

$phpexcel = $phpreader->load($filepath);
/**读取excel文件中的第一个工作表*/
$currentsheet = $phpexcel->getsheet(0);
/**取得最大的列号*/
$allcolumn = $currentsheet->gethighestcolumn();
/**取得一共有多少行*/
$allrow = $currentsheet->gethighestrow();
/**从第二行开始输出,因为excel表中第一行为列名*/
for($currentrow = 2;$currentrow <= $allrow;$currentrow++){
/**从第a列开始输出*/
for($currentcolumn= 'a';$currentcolumn<= $allcolumn; $currentcolumn++){
$val = $currentsheet->getcellbycolumnandrow(ord($currentcolumn) - 65,$currentrow)->getvalue();/**ord()将字符转为十进制数*/
if($currentcolumn == 'a')
{
echo getdata($val)."t";
}else{
//echo $val;
/**如果输出汉字有乱码,则需将输出内容用iconv函数进行编码转换,如下将gb2312编码转为utf-8编码输出*/
echo iconv('utf-8','gb2312', $val)."t";
}
}
echo "</br>";
}
echo "n";
?>

更多php教程,请参考本站的php编程栏目。