php从xlsx里读取数据
要先下载phpexcel,放入extend,重命名时,从xlsx里读取的是utf-8,要转换为gbk,不然会找不到文件。
- <?php
- /**
- * 读取表格内容
- */
- public function load_xls()
- {
- header("Content-type: text/html; charset=utf-8");
- error_reporting(E_ALL ^ E_NOTICE);
- $dir = "./test.xlsx";
- import("exc.PHPExcel");
- //要导入的xls文件位置位置
- $filename = $dir;
- //创建PHPExcel对象,注意,不能少了\
- $PHPExcel = new PHPExcel();
- //如果excel文件后缀名为.xls,导入这个类
- //import("exc.PHPExcel.Reader.Excel5");
- //如果excel文件后缀名为.xlsx,导入这下类
- import("Org.Util.PHPExcel.Reader.Excel2007");
- $PHPReader=new PHPExcel_Reader_Excel2007();
-
- $PHPReader=new PHPExcel_Reader_Excel5();
- //载入文件
- $PHPExcel=$PHPReader->load($filename);
- //获取表中的第一个工作表,如果要获取第二个,把0改为1,依次类推
- $currentSheet=$PHPExcel->getSheet(0);
- //获取总列数
- $allColumn=$currentSheet->getHighestColumn();
- //获取总行数
- $allRow=$currentSheet->getHighestRow();
-
- //循环获取表中的数据,$currentRow表示当前行,从哪行开始读取数据,索引值从0开始
- for($currentRow=2;$currentRow<=$allRow;$currentRow++){
- //从哪列开始,A表示第一列
- for($currentColumn='A';$currentColumn<=$allColumn;$currentColumn++){
- //数据坐标
- $address = $currentColumn.$currentRow;
- //读取到的数据,保存到数组$arr中
- $arr[$currentRow][$currentColumn]=$currentSheet->getCell($address)->getValue();
- }
-
- }
-
- $mp3_file = "./md5/";
-
- foreach ($arr as $key => $value) {
-
- if(!empty($value['B'])&&!empty($value['D'])){
-
- $value['D'] = iconv("UTF-8//IGNORE","GBK",$value['D']);
-
- $mp3_name = $mp3_file.$value['D'].'6 .mp3';
-
- $old_name = $mp3_file.$value['B'];
-
- if(!file_exists($mp3_name)&&file_exists($old_name)){//检测文件名是否重复
- if(rename($mp3_file.$value['B'],$mp3_name)){//将文件重命名
- echo 'ok!<br>';
- }else{
- echo 'not ok!<br>';
- }
- }else{
- echo $mp3_name.'not ok!<br>';
- }
-
-
- }else{
- echo 'error'.'not ok!<br>';
- }
-
- }
-
- }
- ?>
解压密码: detechn或detechn.com
免责声明
本站所有资源出自互联网收集整理,本站不参与制作,如果侵犯了您的合法权益,请联系本站我们会及时删除。
本站发布资源来源于互联网,可能存在水印或者引流等信息,请用户自行鉴别,做一个有主见和判断力的用户。
本站资源仅供研究、学习交流之用,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担。