免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2777 | 回复: 1
打印 上一主题 下一主题

PHPExcel读取Excel文件 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-06 20:22 |只看该作者 |倒序浏览
PHPExcel读取Excel文件










用PHPExcel读取Excel 2007 或者Excel2003文件

涉及知识点:

php对excel文件进行循环读取

php对字符进行ascii编码转化,将字符转为十进制数

php对excel日期格式读取,并进行显示转化

php对汉字乱码进行编码转化
  1. View Code
  2. <?phprequire_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";?>
复制代码

论坛徽章:
0
2 [报告]
发表于 2011-12-20 13:52 |只看该作者
学习鸟
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP