phpexcel开发,PHPexcel

发布时间:2022-11-29

本文目录一览:

  1. thinkphp3.1中的phpexcel导入怎么用
  2. 用php如何写导出excel代码?
  3. phpexcel 支持什么版本的 excel
  4. 原生PHP代码实现excel导入,并添加数据到数据库.
  5. phpexcel 读取excel load方法卡死过不去 代码如下

thinkphp3.1中的phpexcel导入怎么用

首先,去PHPExcel官方网站下载PHPExcel,官方地址为;.我下的是1.8.0版本的.解压后发现还是蛮大的,有十几M,不知道其他版本是不是会小点. 这里写图片描述 把解压好的PHPExcel文件放在ThinkPHP的Vender文件夹下(专门放第三方类库的),如下图 这里写图片描述 其次,创建Excel转换数组类,并把它放在ThinkPHP\Extend\Library\ORG\Util目录下

class ExcelToArrary {
    public function __construct() {
        Vendor("PHPExcel.Classes.PHPExcel");//引入phpexcel类(留意路径,不了解路径可以查看下手册)
        Vendor("PHPExcel.Classes.PHPExcel.IOFactory"); //引入phpexcel类(留意路径)
    }
    public function read($filename,$encode,$file_type){
        if(strtolower ( $file_type )=='xls')//判断excel表类型为2003还是2007
        {
            Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel5"); //引入phpexcel类(留意路径)
            $objReader = PHPExcel_IOFactory::createReader('Excel5');
        }elseif(strtolower ( $file_type )=='xlsx'){
            Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel2007");//引入phpexcel类(留意路径)
            $objReader = PHPExcel_IOFactory::createReader('Excel2007');
        }
        $objReader->setReadDataOnly(true);
        $objPHPExcel = $objReader->load($filename);
        $objWorksheet = $objPHPExcel->getActiveSheet();
        $highestRow = $objWorksheet->getHighestRow();
        $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;
    }
}

现在来说Excel,表格的结构样式和MySQL样式要类似,表格样式如下(本人对Excel使用只是一般,所以如果有Excel大神做的报表,不知后果如何). 这里写图片描述 前端页面相关代码:

<div>
    <form method="post" action="{:U('Index/upload')}" enctype="multipart/form-data">
        <font>导入Excel数据:</font>
        <label for="file_stu">上传</label>
        <input name="file_stu" type="file" id="file_stu" />
        <h3>温馨提示:</h3>
        <p>请确认您的Excel表格类型是xls的,以免出现兼容问题.</p>
        <input type="submit" class="sure" value="导入" />
    </form>
</div>

最后,控制器部分使用了Thinkphp自带的上传类,使用unlink()函数是为了删除上传的excel表格,以免文件夹存入过多文件,调试代码时可先注释掉.或者不写也行,把删除文件的工作交给你们的运维.代码中foreach循环部分$v[]里的0, 1,2可以改动以下看看与Excel表格里的内容是什么关系.可以把数组打印出来看一看,你就很清楚了 相关代码:

public function upload(){
    import('ORG.Util.ExcelToArrary');//导入excelToArray类
    if (! empty ( $_FILES ['file_stu'] ['name'] )) {
        import('ORG.Net.UploadFile');
        $upload = new UploadFile();// 实例化上传类
        $upload->maxSize = 3145728 ;// 设置附件上传大小
        $upload->allowExts = array('xls', 'xlsx');// 设置附件上传类型
        $upload->savePath = './Uploads/';// 设置附件上传目录
        if(!$upload->upload()) {// 上传错误提示错误信息
            $this->error($upload->getErrorMsg());
        } else { // 上传成功 获取上传文件信息
            $info = $upload->getUploadFileInfo();
        }
    } else {
        $this->error('(⊙o⊙)~没传数据就导入?!你在逗我?!');
    }
    $ExcelToArrary = new ExcelToArrary(); //实例化
    $res = $ExcelToArrary->read($info[0]['savepath'].$info[0]['savename'],"UTF-8",$info[0]['extension']); //传参,判断office2007还是office2003
    $res = array_slice($res,1); //为了去掉Excel里的表头,也就是$res数组里的$res[0];
    foreach ( $res as $k => $v ){ //循环excel表
        $data[$k]['mobile'] = $v [0]; //创建二维数组
        $data[$k]['name'] = $v [1];
        $data[$k]['duty'] = $v [2];
    }
    $result = M('appkey')->addAll($data);
    if(!$result){
        $this->error('导入数据库失败');
        exit();
    } else {
        $filename = './Uploads/'.$info[0]['savename'];//上传文件绝对路径,unlink()删除文件函数
        if (unlink($filename)) {
            $this->success ( '导入成功' );
        } else {
            $this->error('缓存删除失败');
        }
    }
}

用php如何写导出excel代码?

用PHPExcel,PHPExcel是相当强大的 MS Office Excel 文档生成类库。 你上它的官/网把程序包下/载下来,里面有 PHPExcel 的程序、还有30个实例程序和三个文档。 看一下其中的开发文档你就会用了。 读取(这段在开发文档里有的,在13页):

require_once '../Classes/PHPExcel/IOFactory.php';
$objReader = PHPExcel_IOFactory::createReader('Excel2007');
$objReader->setReadDataOnly(true);
$objPHPExcel = $objReader->load("test.xlsx");
$objWorksheet = $objPHPExcel->getActiveSheet();
echo '<table>' . "\n";
foreach ($objWorksheet->getRowIterator() as $row) {
    echo '<tr>' . "\n";
    $cellIterator = $row->getCellIterator();
    $cellIterator->setIterateOnlyExistingCells(false);
    foreach ($cellIterator as $cell) {
        echo '<td>' . $cell->getValue() . '</td>' . "\n";
    }
    echo '</tr>' . "\n";
}
echo '</table>' . "\n";

phpexcel 支持什么版本的 excel

phpexcel 支持生成Excel(.xls)、Excel2007(.xlsx)文档,此外还支持PDF、HTML、CSV文档的生成。此外,PHPExcel还支持以现有的Excel文档为模板填充数据生成新的以上文档。并且,其本身的API文档和示例demo相当完整,非常有助于开发人员使用。 当前的版本是1.7.6,下载解压后的PHPExcel的目录结构如下所示: 其中:

  • Classes目录下是PHPExcel的源代码文件:PHPExcel.php文件是类库的接口,外部的PHP代码通过它来实现对PHPExcel的调用;PHPExcel目录下是各种不同文档(如Excel、Excel2007、PDF等)的读取和生成的具体操作代码,它们由Classes目录下的PHPExcel.php文件通过工厂模式统一进行调用。
  • Documentation目录下是PHPExcel的官方帮助文档,尤其是API目录下网页文件全部是PHPExcel的API帮助文档,而其它的则是对这个开源项目的介绍。
  • Tests目录下是PHPExcel的将近40个示例小程序,可以与Classes目录一同放到Apache+PHP环境下进行测试与学习。

原生PHP代码实现excel导入,并添加数据到数据库.

我用的代码是:

<?php
//连接数据库文件
$connect = mysql_connect("localhost","admin","admin") or die("链接数据库失败!");
//连接数据库(test)
mysql_select_db("testcg",$connect) or die (mysql_error());
$temp = file("test.csv");//连接EXCEL文件,格式为了.csv
for ($i=0;$i < count($temp);$i++) {
    $string = explode(",",$temp[$i]);//通过循环得到EXCEL文件中每行记录的值
    //将EXCEL文件中每行记录的值插入到数据库中
    $q = "insert into ceshi (name,num,dom) values('$string[0]','$string[1]','$string[2]');";
    mysql_query($q) or die (mysql_error());
    if (!mysql_error()) {
        echo " 成功导入数据!";
    }
    echo $string[4]."\n";
    unset($string);
}
?>

phpexcel或者pear的一个组件 ,国内有一个excelclass的插件 都是用来处理excel的,前2个功能都比较强大,对编码的支持也都不错,推荐使用pear的那个,名字好像叫spreadsheet reader phpexcel比较费资源,不过并不是所有的excel都能读取 楼主可以到这里去看看 pear.php.net

顶楼上的回答~~顺便接个分!嘿嘿

AdO直接上传 注意有些字符mysql或ADO可能不支持

首先确认你的数据库是什么编码的,以utf-8为例, 你首先打开excel 文件,然后保存,选择为另存为.csv文件。 然后用文本编辑器打开.csv文件,另存为utf-8的csv 然后你写php 可以使用php 的getcsv 打开(这样确保你有的字段中含有,而导致解析错误),然后把解析的结果导入到数据库中。 然后完了。

phpexcel 读取excel load方法卡死过不去 代码如下

PHP读EXECL不要用ODBC,直接用一个类就可以了phpExcelReader这个类是老外一直在开发的类,里面涵盖了几乎所有EXECL的读取和写入功能,甚至图片和批注都可以读,我觉得这个类可以满足你所有PHP关于EXECL的读写工作完成任务就要用做好的方法,一直用一种自己会但不是最好法总归不是好程序员所为,加油吧。