您好,登录后才能下订单哦!
小编给大家分享一下PHP读取Excel类文件的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
1、执行速度快。2、具有很好的开放性和可扩展性。3、PHP支持多种主流与非主流的数据库。4、面向对象编程:PHP提供了类和对象。5、版本更新速度快。6、具有丰富的功能。7、可伸缩性。8、功能全面,包括图形处理、编码与解码、压缩文件处理、xml解析等。
想要使用PHP读取Excel文件必然要用到PHPExcel开源类库,网上资源应该挺多的。但是每一种的操作必然都是不同的,可原理应该都是大同小异。
这个文件夹里包含的就是PHPExcel类文件
,在外面还有一个入口PHP文件
处理机制: 1.读取Excel文件
2.获取最大行号和最大列号
3.通过行数循环里面嵌套列数循环来用特殊符号拼接每个小表格里面的数据得到一个字符串
4.然后使用explode拆分函数将字符串拆分后就得到了一个二维数组(即表格里面的数据)。
代码示例
$path = "/wamp/www/xiong/hadf"; if(is_dir($path)){ echo "存在"; }else{ mkdir($path, 0777, true); echo "chuangji"; } require_once"./PHPExcel.php"; $filePath = "./1233.xlsx"; $PHPReader = new PHPExcel_Reader_Excel2007(); if(!$PHPReader->canRead($filePath)) { $PHPReader = new PHPExcel_Reader_Excel5(); if(!$PHPReader->canRead($filePath)) { echo 'no Excel'; exit; } } $PHPExcel = $PHPReader->load($filePath); /**读取excel文件中的第一个工作表*/ $currentSheet = $PHPExcel->getSheet(0); /**取得最大的列号*/ $allColumn = $currentSheet->getHighestColumn(); // echo $allColumn;exit; /**取得一共有多少行*/ $allRow = $currentSheet->getHighestRow(); /**从第二行开始输出,因为excel表中第一行为列名*/ $val = ''; for($currentRow = 1; $currentRow <= $allRow; $currentRow++) { /**从第A列开始输出*/ for($currentColumn = 'A'; $currentColumn <= $allColumn; $currentColumn++) { $val .= $currentSheet->getCellByColumnAndRow(ord($currentColumn) - 65,$currentRow);//->getValue();/**ord()将字符转为十进制数*/ $val .= "&%|%&"; /**如果输出汉字有乱码,则需将输出内容用iconv函数进行编码转换,如下将GBK编码转为UTF-8编码输出*/ //$val .= iconv('GBK','UTF-8', $val); } $val .= "\n"; }$member_info_arr = explode("\n", $val); unset($member_info_arr[count($member_info_arr) - 1]); $present_time = date("Y-m-d H:i:s"); if(count($member_info_arr) <= 0) { sys_msg_json(0, "会员信息文件中无数据,请添加"); } unset($member_info_arr[0]); // var_dump($member_info_arr);exit; foreach ($member_info_arr as $key => $val) { $arr[$key] = explode("&%|%&",$val); } // var_dump($arr);exit; foreach ($arr as $key => $val) { unset($arr[$key][2]); } var_dump($arr);
以上是“PHP读取Excel类文件的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。