phpexcel 导入导出

导出excel

/**
 * 以下是使用示例,对于以 //// 开头的行是不同的可选方式,请根据实际需要
 * 打开对应行的注释。
 * 如果使用 Excel5 ,输出的内容应该是GBK编码。
 */
//require_once ‘PHPExcel.php‘;
// uncomment
////require_once ‘PHPExcel/Writer/Excel5.php‘;    // 用于其他低版本xls
// or
////require_once ‘PHPExcel/Writer/Excel2007.php‘; // 用于 excel-2007 格式
$objExcel = new PHPExcel();  // 创建一个处理对象实例
// 创建文件格式写入对象实例, uncomment
$objWriter = new PHPExcel_Writer_Excel5($objExcel);   // 用于其他版本格式
// or
////$objWriter = new PHPExcel_Writer_Excel2007($objExcel); // 用于 2007 格式
//$objWriter->setOffice2003Compatibility(true);  

//*************************************
//设置文档基本属性
$objProps = $objExcel->getProperties();
//$objProps->setCreator("Zeal Li");
//$objProps->setLastModifiedBy("Zeal Li");
//$objProps->setTitle("Office XLS Test Document");
//$objProps->setSubject("Office XLS Test Document, Demo");
//$objProps->setDescription("Test document, generated by PHPExcel.");
//$objProps->setKeywords("office excel PHPExcel");
//$objProps->setCategory("Test"); 

//*************************************
//设置当前的sheet索引,用于后续的内容操作。
//一般只有在使用多个sheet的时候才需要显示调用。
//缺省情况下,PHPExcel会自动创建第一个sheet被设置SheetIndex=0  

$objExcel->setActiveSheetIndex(0);
$objActSheet = $objExcel->getActiveSheet();

//设置当前活动sheet的名称
$objActSheet->setTitle(‘测试Sheet‘);  

//设置单元格内容
//
//由PHPExcel根据传入内容自动判断单元格内容类型
$objActSheet->setCellValue(‘A1‘, ‘字符串内容‘);  // 字符串内容
$objActSheet->setCellValue(‘A2‘, 26);            // 数值
$objActSheet->setCellValue(‘A3‘, true);          // 布尔值
$objActSheet->setCellValue(‘A4‘, ‘=SUM(A2:A2)‘); // 公式  

//显式指定内容类型
$objActSheet->setCellValueExplicit(‘A5‘, ‘847475847857487584‘,
                                   PHPExcel_Cell_DataType::TYPE_STRING);  

//合并单元格
$objActSheet->mergeCells(‘B1:C22‘);  

//分离单元格
$objActSheet->unmergeCells(‘B1:C22‘);  

//*************************************
//设置单元格样式
//  

//设置宽度
$objActSheet->getColumnDimension(‘B‘)->setAutoSize(true);
$objActSheet->getColumnDimension(‘A‘)->setWidth(30);  

$objStyleA5 = $objActSheet->getStyle(‘A5‘);  

//设置单元格内容的数字格式。
//
//如果使用了 PHPExcel_Writer_Excel5 来生成内容的话,
//这里需要注意,在 PHPExcel_Style_NumberFormat 类的 const 变量定义的
//各种自定义格式化方式中,其它类型都可以正常使用,但当setFormatCode
//为 FORMAT_NUMBER 的时候,实际出来的效果被没有把格式设置为"0"。需要
//修改 PHPExcel_Writer_Excel5_Format 类源代码中的 getXf($style) 方法,
//在 if ($this->_BIFF_version == 0x0500) { (第363行附近)前面增加一
//行代码:
//if($ifmt === ‘0‘) $ifmt = 1;
//
//设置格式为PHPExcel_Style_NumberFormat::FORMAT_NUMBER,避免某些大数字
//被使用科学记数方式显示,配合下面的 setAutoSize 方法可以让每一行的内容
//都按原始内容全部显示出来。
$objStyleA5
    ->getNumberFormat()
    ->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_NUMBER);  

//设置字体
$objFontA5 = $objStyleA5->getFont();
$objFontA5->setName(‘Courier New‘);
$objFontA5->setSize(10);
$objFontA5->setBold(true);
$objFontA5->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE);
$objFontA5->getColor()->setARGB(‘FF999999‘);  

//设置对齐方式
$objAlignA5 = $objStyleA5->getAlignment();
$objAlignA5->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
$objAlignA5->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);  

//设置边框
$objBorderA5 = $objStyleA5->getBorders();
$objBorderA5->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
$objBorderA5->getTop()->getColor()->setARGB(‘FFFF0000‘); // color
$objBorderA5->getBottom()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
$objBorderA5->getLeft()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
$objBorderA5->getRight()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);  

//设置填充颜色
$objFillA5 = $objStyleA5->getFill();
$objFillA5->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
$objFillA5->getStartColor()->setARGB(‘FFEEEEEE‘);  

//从指定的单元格复制样式信息.
$objActSheet->duplicateStyle($objStyleA5, ‘B1:C22‘);  

//*************************************
//添加图片
$objDrawing = new PHPExcel_Worksheet_Drawing();
$objDrawing->setName(‘ZealImg‘);
$objDrawing->setDescription(‘Image inserted by Zeal‘);
$objDrawing->setPath(‘./zeali.net.logo.gif‘);
$objDrawing->setHeight(36);
$objDrawing->setCoordinates(‘C23‘);
$objDrawing->setOffsetX(10);
$objDrawing->setRotation(15);
$objDrawing->getShadow()->setVisible(true);
$objDrawing->getShadow()->setDirection(36);
$objDrawing->setWorksheet($objActSheet);  

//添加一个新的worksheet
$objExcel->createSheet();
$objExcel->getSheet(1)->setTitle(‘测试2‘);  

//保护单元格
$objExcel->getSheet(1)->getProtection()->setSheet(true);
$objExcel->getSheet(1)->protectCells(‘A1:C22‘, ‘PHPExcel‘);  

//*************************************
//输出内容
//  

$outputFileName = $title . ".xls";
header("Content-Type: application/force-download");
header("Content-Type: application/octet-stream");
header("Content-Type: application/download");
header(‘Content-Disposition:attachment;filename="‘ . $outputFileName . ‘"‘);  //到文件
////header(‘Content-Disposition:inline;filename="‘.$outputFileName.‘"‘);  //到浏览器
header("Content-Transfer-Encoding: binary");
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Pragma: no-cache");
$objWriter->save(‘php://output‘);

example:

$phpexcelPath = APPPATH.‘libraries/phpexcel_1.8.0_doc/classes/PHPExcel.php‘;  //CI引入PHPExcel

$objPHPExcel = new PHPExcel();

        //set width
        $objPHPExcel->getActiveSheet()->getColumnDimension(‘A‘)->setWidth(‘50‘);
        $objPHPExcel->getActiveSheet()->getColumnDimension(‘B‘)->setWidth(‘50‘);

        $firstSheet = $objPHPExcel->setActiveSheetIndex(0);
        $firstSheet->setCellValue(‘A1‘,"好呀");
        $firstSheet->setCellValue(‘B1‘,date(‘Y-m-d H:i:s‘,time()));
        $firstSheet->setCellValue(‘A2‘,"dd hello");
        $firstSheet->setCellValue(‘B2‘,$this->gbk_to_utf8("哈哈呵可耶 hello"));// 哈哈呵可耶 hello

        //Rename sheet
        $objPHPExcel->getActiveSheet()->setTitle("Simple");

        //set active sheet index to the first sheet.
        $objPHPExcel->setActiveSheetIndex(0);

        //save excel
        $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel,‘Excel2007‘);//Excel2007   Excel5
        $fileName = "order_information";

//         $dirName=APPPATH."../upload/";
//         if(!opendir($dirName))
//             mkdir($dirName);
//         $objWriter->save($dirName.$fileName.‘.xlsx‘);  // 到磁盘

        header("Content-Type: application/force-download");
        header("Content-Type: application/octet-stream");
        header("Content-Type: application/download");
        header(‘Content-Disposition:attachment;filename="‘ . $fileName . ‘.xlsx"‘);  //到文件
        ////header(‘Content-Disposition:inline;filename="‘.$outputFileName.‘"‘);  //到浏览器
        header("Content-Transfer-Encoding: binary");

        $objWriter->save(‘php://output‘);

PHPExcel常用方法汇总

导入excel

$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);
$currentSheet = $PHPExcel->getSheet(0); /* * 读取excel文件中的第一个工作表 */
$allColumn = $currentSheet->getHighestColumn();/**取得最大的列号*/
$allRow = $currentSheet->getHighestRow(); /* * 取得一共有多少行 */
PHPExcel_Cell::columnIndexFromString(); //字母列转换为数字列 如:AA变为27
for ($currentRow = 2; $currentRow <= $allRow; $currentRow = $currentRow + 2) {
    $pair_name = $currentSheet->getCellByColumnAndRow(0, $currentRow)->getValue();
    $trailtime = $currentSheet->getCellByColumnAndRow(3, $currentRow)->getValue();
    $trailtime = date("Y-m-d H:i:s", PHPExcel_Shared_Date::ExcelToPHP($trailtime) - 28800); //时间的转换

}
public function excel_start_card_import(){
        $this->_check_admin_permission(‘启动卡池管理‘);

        $xlsfile = @$_FILES[‘xlsfile‘];

        if($xlsfile[‘name‘]){

            $result = $this->getExcelData($xlsfile[‘tmp_name‘],‘excel/excel_start_card_import‘);

            $success_num = 0;
            $all_num = count($result);
            $allFieldCount = 24;
            //用事务提交
            $this->model_common->query(‘BEGIN‘);
            for($i = 0; $i<$all_num ;$i++){
                if($allFieldCount != count($result[$i]))
                {
                    $this->_admin_prompt(site_url(‘excel/excel_start_card_import‘), "Excel表格的数据数目与表字段不符!请检查Excel表格的数据.");
                    exit;
                }

                $sql = "insert into o_active_cardpool (
                        MOBILE,COUNTRY_CODE,OPERATOR,AREA_NUM,STANDARD_TYPE,
                        CARD_VERSION,NUM,ICCID,IMSI,UIMID,SID,ACCOLC,NID,AKEY,
                        PIN1,PIN2,PUK1,PUK2,ADM,HRPDUPP,HRPDSS,STATUS,
                        BEGIN_TIME,END_TIME)
                        VALUES(‘{$result[$i][0]}‘,‘{$result[$i][1]}‘,‘{$result[$i][2]}‘,‘{$result[$i][3]}‘,‘{$result[$i][4]}‘
                        ,‘{$result[$i][5]}‘,‘{$result[$i][6]}‘,‘{$result[$i][7]}‘,‘{$result[$i][8]}‘
                        ,‘{$result[$i][9]}‘,‘{$result[$i][10]}‘,‘{$result[$i][11]}‘,‘{$result[$i][12]}‘
                        ,‘{$result[$i][13]}‘,‘{$result[$i][14]}‘,‘{$result[$i][15]}‘,‘{$result[$i][16]}‘
                        ,‘{$result[$i][17]}‘,‘{$result[$i][18]}‘,‘{$result[$i][19]}‘,‘{$result[$i][20]}‘
                        ,‘{$result[$i][21]}‘,‘{$result[$i][22]}‘,‘{$result[$i][23]}‘)";

                if($this->model_common->query($sql))
                    $success_num++;
                if($i%5000==0){
                    $this->model_common->query(‘COMMIT‘);
                    $this->model_common->query(‘BEGIN‘);
                }

            }
            $this->model_common->query(‘COMMIT‘);

            $this->_admin_prompt(site_url(‘excel/excel_start_card_import‘), "数据导入成功!总数是:{$all_num} 成功数是:{$success_num}");
            exit;

        }

        $data = array();

        $this->_set_data($data);
        $this->_set_view(‘excel_start_card_import‘,$this->_DATA);
    }

    private function getExcelData($pathName,$redirectUrl)
    {
        //$phpExcel = new PHPExcel();
        $PHPReader = new PHPExcel_Reader_Excel2007();
        if(!$PHPReader->canRead($pathName)){
            $PHPReader = new PHPExcel_Reader_Excel5();
            if(!$PHPReader->canRead($pathName)){
                $this->_admin_prompt(site_url($redirectUrl), "抱歉,不能读取该文件!");
                exit;
            }
        }

        $phpExcel = $PHPReader->load($pathName);
        $currentSheet = $phpExcel->getSheet(0); //得到第一个sheet工作区
        $allColumn = $currentSheet->getHighestColumn(); //总列数
        $allRow = $currentSheet->getHighestRow();  //总行数

        $result = array();
        for($currentRow = 2;$currentRow<=$allRow;$currentRow++){
            //遍历行中的每个字段
            for($currentColumn = ‘A‘;$currentColumn<=$allColumn; $currentColumn++){
                $val = $currentSheet->getCellByColumnAndRow(ord($currentColumn)-65,$currentRow)->getValue();
//                 $val = $currentSheet->getCell($currentColumn.$currentRow)->getValue();//A1
//                 if($val===NULL)
//                     break;

                if($val instanceof PHPExcel_RichText)
                    $val = $val->__toString();
                $val = $this->utf8_to_gbk($val);

                $result[$currentRow-2][ord($currentColumn)-65] = $val;
            }
        }

        //var_dump($this->utf8_to_gbk($currentSheet->getHighestColumn().‘  -  ‘.$currentSheet->getHighestRow()));
        return $result;
    }
时间: 2024-11-13 04:51:29

phpexcel 导入导出的相关文章

PHPExcel导入导出

慕课教程 -- PHPExcel导入导出 一.PHPExcel导出操作 1.快速入门 <?php #找到当前脚本的路径 $dir = dirname(__FILE__); #引入PHPExcel插件文件 require $dir."/excel/PHPExcel.php"; #实例化PHPExcel类 $objPHPExcel = new PHPExcel(); #获得当前活动sheet的操作对象 $objSheet = $objPHPExcel->getActiveShe

使用PHPExcel导入导出excel格式文件

使用PHPExcel导入导出excel格式文件 作者:zccst 由于导出使用较多,下面是导出实现过程. 第一步,将PHPExcel的源代码复制到项目的lib下 文件包括:PHPExcel.php 和 文件夹PHPExcel 源代码见附件 注1:源代码是zip格式,能在windows和linux通用. 注2:PHPExcel.zip是干净代码,可以直接引用.PHPExcel2.zip有svn记录,不适合直接引用. 第二步:在需要导出的handler页面中引用 1,在头部引入三个文件 Php代码 

thinkphp5 使用PHPExcel 导入导出

首先下载PHPExcel类.网上很多,自行下载. 然后把文件放到vendor文件里面. 一般引用vendor里面的类或者插件用vendor(); 里面加载的就是vendor文件,然后想要加载哪个文件,直接写就行,中间的"."相当于文件路径的"/". 例如加载excel5这个文件: 先把html代码贴出来(整个导入导出的): <form enctype="multipart/form-data" method="post"

PHPExcel导入导出常用方法总结

最近公司后台管理系统需求,要用PHP导出excel表格数据,所以特整理了一下常用的方法供大家参考: PHPExcel扩展包地址:https://github.com/wanqianworld/phpexcel-1.8 大致的分为几个部分: 一.导出的方法及步骤 1.引入PHPExcel文件:require_once("../Classes/PHPExcel.php"); 2.实例化PHPExcel:$ObjPHPExcel = new PHPExcel(); 3.获取当前工作sheet

thinkphp上传至服务器后PhpExcel导入导出的若干问题

在将tp5项目上传到服务器后,原来的系统有部分功能无法实现,在批量到如时报错 mkdir(): Device or resource: 查看了一下这是权限的问题,因此打开服务器中的项目,将controller控制器中的导入代码的文件位置进行修改: 这里改为你自己定义的文件夹位置. 点开文件夹属性->安全 设置此文件夹可以让所有用户读取和写入. 设置完成再次点击导入,发现报错: Warning: "continue" targeting switch is equivalent t

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

写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xml的也用过,csv的就更不用谈了.呵呵.(COM方式不讲了,这种可读的太多了,我也写过利用wps等进行word等的生成之类的文章 )但是在读的时候,只用过一种,具体是什么忘了,要回去翻代码了.基本上导出的文件分为两种:1:类Excel格式,这个其实不是传统意义上的Excel文件,只是因为Excel的兼容能力强,能够正确打开而已.修改这种文件后再保存,通常会提示你是否要转换成Excel文件.优

PHP导入导出Excel方法

看到这篇文章的时候,很是惊讶原作者的耐心,虽然我们在平时用的也 有一些,但没有作者列出来的全,写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xml的也用 过,csv的就更不用谈了.呵呵.(COM方式不讲了,这种可读的太多了,我也写过利用wps等进行word等的生成之类的文章 )但是在读的时候,只用过一种,具体是什么忘了,要回去翻代码了.因为采用的是拿来主义,记不住.原文地址:http://xinsync.xju.edu.cn/index.p

PHP使用PHPEXCEL导入Excel

下载PHPEXCEL 后放到项目里. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 public function InExcel() {     //设定缓

PHP导入导出Excel方法小结

基本上导出的文件分为两种: 1:类Excel格式,这个其实不是传统意义上的Excel文件,只是因为Excel的兼容能力强,能够正确打开而已.修改这种文件后再保存,通常会提示你是否要转换成Excel文件.优点:简单.缺点:难以生成格式,如果用来导入需要自己分别编写相应的程序.2:Excel格式,与类Excel相对应,这种方法生成的文件更接近于真正的Excel格式. 如果导出中文时出现乱码,可以尝试将字符串转换成gb2312,例如下面就把$yourStr从utf-8转换成了gb2312:$yourS