首先:下载好PHPExcel类库文件

视图层:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
    <title></title>
</head>
<body>
    <form action="<?php echo site_url('admin/excel/import_pro') ?>" method='post' enctype="multipart/form-data" >
     <input type="file" name='file_stu' />
     <input type="submit" value='导入' />
    </form>
</body>
</html>

控制器:

<?php
defined('BASEPATH') OR exit('No direct script access allowed');
class Excel extends CI_Controller{
    function __construct()
    {
        parent::__construct();
        //$this->load->library('PHPExcel');
        //$this ->load ->library('PHPExcel/IOFactory');
    }
    //从数据表导出到excel
    public function export($table_name){
        $query = $this -> db -> get($table_name);
        //print_r($query);
        if(!$query)return false;
        // StartingthePHPExcellibrary
        //加载PHPExcel类
        $this->load->library('PHPExcel');
        $this ->load ->library('PHPExcel/IOFactory');
        $objPHPExcel = new PHPExcel();
        $objPHPExcel->getProperties()-> setTitle("export") -> setDescription("none");
        $objPHPExcel -> setActiveSheetIndex(0);
        // Fieldnamesinthefirstrow
        $fields = $query -> list_fields();
        $col = 0;
        foreach($fields as $field){
            $objPHPExcel -> getActiveSheet() -> setCellValueByColumnAndRow($col, 1,$field);
            $col++;
        }
            // Fetchingthetabledata
         $row = 2;
         foreach($query->result() as $data)
         {
             $col = 0;
             foreach($fields as $field)
             {
             $objPHPExcel->getActiveSheet()->setCellValueByColumnAndRow($col,$row,$data->$field);
             $col++;
             }
            $row++;
        }
        $objPHPExcel -> setActiveSheetIndex(0);
        $objWriter = IOFactory :: createWriter($objPHPExcel, 'Excel5');
        // Sendingheaderstoforcetheusertodownloadthefile
        header('Content-Type:application/vnd.ms-excel');
        //header('Content-Disposition:attachment;filename="Products_' . date('dMy') . '.xls"');
        header('Content-Disposition:attachment;filename="Brand_' . date('Y-m-d') . '.xls"');
        header('Cache-Control:max-age=0');
        $objWriter -> save('php://output');
    }
    //从excel导入到数据表
    function import(){
        $this->load->view('excel_import.html');
    }
    //从excel导入到数据表
    function import_pro(){
       //要处理的excel文件
       //$filename = './sampleData/example2.xls';//指定文件
       //用用选择excel文件
       //print_r($_FILES);exit;
       $tmp_file = $_FILES ['file_stu'] ['tmp_name'];
       $file_types = explode ( ".", $_FILES ['file_stu'] ['name'] );
       $file_type = $file_types [count ( $file_types ) - 1];
       /*判别是不是.xls文件,判别是不是excel文件*/
       if (strtolower ( $file_type ) != "xls"){
           $this->error ( '不是Excel文件,重新上传' );
       }
       $savePath = "Public/uploads/excel/";
       /*以时间来命名上传的文件*/
       $str = date ( 'Ymdhis' );
       $file_name = $str . "." . $file_type;
       /*是否上传成功*/
       if(!copy($tmp_file,$savePath.$file_name)){
           $this->error ( '上传失败' );
       }
       //要获得新的文件路径+名字
       $fullpath = $savePath.$file_name;
       //echo $fullpath;
       $re = $this->read($fullpath,'utf-8');
       //var_dump($re);
       return $re;
    }

public function read($filename,$encode='utf-8'){
        $this ->load ->library('PHPExcel/IOFactory');
        $objReader = IOFactory::createReader('Excel5');
        $objReader->setReadDataOnly(true);
        $objPHPExcel = $objReader->load($filename);
        $objWorksheet = $objPHPExcel->getActiveSheet();
        $highestRow = $objWorksheet->getHighestRow();
        //echo $highestRow;
        $highestColumn = $objWorksheet->getHighestColumn();
        $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);
        $excelData = array();
        for($row = 1; $row <= $highestRow; $row++) {
            for ($col = 0; $col < $highestColumnIndex; $col++) {
                $excelData[$row][]=(string)$objWorksheet->getCellByColumnAndRow($col, $row)->getValue();
                }
        }
        return $excelData;
        }
}

具体内容,自己操作便知!

php导入导出的更多相关文章

  1. CRL快速开发框架系列教程九(导入/导出数据)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  2. ITTC数据挖掘平台介绍(五) 数据导入导出向导和报告生成

    一. 前言 经过了一个多月的努力,软件系统又添加了不少新功能.这些功能包括非常实用的数据导入导出,对触摸进行优化的画布和画笔工具,以及对一些智能分析的报告生成模块等.进一步加强了平台系统级的功能. 马 ...

  3. ASP.NET Core 导入导出Excel xlsx 文件

    ASP.NET Core 使用EPPlus.Core导入导出Excel xlsx 文件,EPPlus.Core支持Excel 2007/2010 xlsx文件导入导出,可以运行在Windows, Li ...

  4. Oracle 数据库导入导出 dmp文件

    转自: http://hi.baidu.com/ooofcu/blog/item/ec5d1f9580d41f007af48077.html 首先询问对方数据库的表空间名称和大小,然后在你的oracl ...

  5. Oracle导入导出

    Oracle 10g 已经引入了数据泵(点击Data Dump)技术,这项技术和之前的exp/imp有哪些好处呢,简单的来说就是恢复和备份速度非常快: 在说明数据泵的使用方法之前,我们先来了解二者的区 ...

  6. csv表格处理(上)-- JS 与 PHP 协作导入导出

    CSV简介 在开发后台管理系统的时候,几乎无可避免的会遇到需要导入导出Excel表格的需求.csv也是表格的一种,其中文名为“逗号分隔符文件”.在Excel中打开如下图左边所示,在记事本打开如下图右边 ...

  7. PHP导入导出excel表格图片(转)

    写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xml的也用过,csv的就更不用谈了.呵呵.(COM方式不讲了,这种可读的太多了,我也写过利用wp ...

  8. excel的导入导出的实现

    1.创建Book类,并编写set方法和get方法 package com.bean; public class Book { private int id; private String name; ...

  9. 利用反射实现通用的excel导入导出

    如果一个项目中存在多种信息的导入导出,为了简化代码,就需要用反射实现通用的excel导入导出 实例代码如下: 1.创建一个 Book类,并编写set和get方法 package com.bean; p ...

  10. thinkphp导入导出excel表单数据

    在PHP项目经常要导入导出Excel表单. 先去下载PHPExcel类库文件,放到相应位置. 我在thinkphp框架中的位置为ThinkPHP/Library/Org/Util/ 导入 在页面上传e ...

随机推荐

  1. SQL查询一周内过生日的用户

    SELECT birthday, )) + '-' + )) + '-' + )) AS datetime) AS Nbirthday FROM CRM_Customer WHERE birthday ...

  2. AMQP协议

    当前各种应用大量使用异步消息模型,并随之产生众多消息中间件产品及协议,标准的不一致使应用与中间件之间的耦合限制产品的选择,并增加维护成本. AMQP是一个提供统一消息服务的应用层标准协议,基于此协议的 ...

  3. WebMethod属性详解

    WebMethod有6个属性:.Description.EnableSession.MessageName.TransactionOption.CacheDuration.BufferResponse ...

  4. Function---hdu5875(大连网选,区间连续求余)

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5875 题意:有n个数,m个查询,每个查询有一个区间[L, R], 求ans, ans = ...

  5. App 上线流程

    http://www.cocoachina.com/bbs/read.php?tid=330302

  6. <转>RowState 介绍

    1. RowState 介绍 RowState 是 DataRow 很重要的一个属性, 表示 DataRow 当前的状态. RowState 有 Added, Modified, Unchanged, ...

  7. iOS 时间戳

    时间戳用过一回,总结一下: 1.在Terminal下获得时间戳: date +%s 原来要在服务器端挂文档,方便开发商下载,用时间戳作为文件名称来区分. 2.在程序下获得时间戳: NSDate * n ...

  8. JMeter学习-014-JMeter 配置元件实例之 - 用户定义的变量 参数化配置

    前文讲述了通过 CSV Data Set Config 实现参数化配置(详情敬请参阅:JMeter学习-010-JMeter 配置元件实例之 - CSV Data Set Config 参数化配置), ...

  9. win10 + gtx1060 + cuda8.0 + caffe + vs2013

    1. 安装cuda8.0 1)先去官网下载cuda8.0  https://developer.nvidia.com/cuda-toolkit 2)下载完之后进行安装,安装时间有点长,请耐心等待,默认 ...

  10. JavaScript:画廊案例

    经常会在网上看到这样的操作:有几个按钮.可以控制器图片的上一张.下一张.那么现在就使用按钮的click单击事件来切换img的图片. 此时由于只是简单的演示,将所有的图片保存在images目录中.所有的 ...