excel的导入导出
2016-04-05 11:27
260 查看
导入
导出
public function excel_put(){ //先做一个文件上传,保存文件 $path=$_FILES['file']; $filePath = "uploads/".$path["name"]; move_uploaded_file($path["tmp_name"],$filePath); //默认用excel2007读取excel,若格式不对,则用之前的版本进行读取 //表格字段名字 $data=array('B'=>'name','C'=>'pwd','D'=>'money1','E'=>'salt'); $tablename='user1';//表名字 $this->excel_fileput($filePath,$data,$tablename); } private function excel_fileput($filePath,$data,$tablename){ $this->load->library("phpexcel");//ci框架中引入excel类 $PHPExcel = new PHPExcel(); $PHPReader = new PHPExcel_Reader_Excel2007(); if(!$PHPReader->canRead($filePath)){ $PHPReader = new PHPExcel_Reader_Excel5(); if(!$PHPReader->canRead($filePath)){ echo 'no Excel'; return ; } } // 加载excel文件 $PHPExcel = $PHPReader->load($filePath); // 读取excel文件中的第一个工作表 $currentSheet = $PHPExcel->getSheet(0); // 取得最大的列号 $allColumn = $currentSheet->getHighestColumn(); // 取得一共有多少行 $allRow = $currentSheet->getHighestRow(); // 从第二行开始输出,因为excel表中第一行为列名 for($currentRow = 2;$currentRow <= $allRow;$currentRow++){ /**从第A列开始输出*/ //echo $allColumn; for($currentColumn= 'A';$currentColumn<= $allColumn; $currentColumn++){ $val = $currentSheet->getCellByColumnAndRow(ord($currentColumn) - 65,$currentRow)->getValue(); //print_r($val); //die; if($currentColumn == 'A') { //echo $val."\t"; }else if($currentColumn <= $allColumn){ $data1[$currentColumn]=$val; } } foreach($data as $key=>$val){ $data2[$val]=$data1[$key]; } $this->db->insert($tablename,$data2); //print_r($data2); //echo "</br>"; } //echo "\n"; echo "导入成功"; }
导出
header("Content-type:application/vnd.ms-excel"); header("Content-Disposition:attachment;filename=123.xls"); $array=$this->db->get("shop_address")->result_array(); $str = "Id\tName\tPid\n"; foreach ($array as $val) { $str .= $val['id'] . "\t" .$val['name'] . "\t" . $val['pid'] . "\n"; } echo $str;
相关文章推荐
- 禁用ssh公钥检查
- 如何在ASP.NET 5上搭建基于TypeScript的Angular2项目
- 微软TFS Agile/CMMI/Scrum
- PowerDesigner的使用
- (转载)JVM实现synchronized的底层机制
- 小白鼠喝毒水的问题。
- Xamarin For Everyone
- 使用苹果原生API进行二维码和条形码的扫描
- 内存分区;堆 栈 全局区 文字常量区 程序代码区
- 在windows中将Tomcat作为服务启动
- 深入浅析Android消息机制
- 自动获取本地IP,通过IP来获取详细的地域信息
- 学会考虑成本,你才能成长更快
- 实现action的统配
- gcc编译参数-fPIC的一些问题
- mongodb的使用
- 【BZOJ-1449&2895】球队收益&球队预算 最小费用最大流
- 多功能时钟应用
- Java的接口和抽象类
- linux环境下集成ant+jmeter+jenkins自动化测试