程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> ExcelFileParser處理excel獲得數據 可作批量導入到數據庫

ExcelFileParser處理excel獲得數據 可作批量導入到數據庫

編輯:關於PHP編程

ExcelFileParser處理excel獲得數據 可作批量導入到數據庫

提交表單

<!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">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Excel數據獲取演示</title>
<meta name="Keywords" content="TODO" />
<meta name="Description" content="TODO"/>
</head>
<body>
    <div>
      <div>Excel數據獲取演示</div>
      <div>
        <form method="POST" action="/Index/parse" enctype="multipart/form-data">
            <input type="file" name="excel" value="" />
            <input type="submit" name="submit" value="提交" />
        </form>
      </div>
    </div>
</body>
</html>


提交處理
[php]
<?php
/**
* CopyRight (c) 2009,
* All rights reserved.
* 文件名:
* 摘  要:
*
* @author 星期八 [email protected]
* @version
*/

class IndexAction extends Action
{
    /**
     * 構造函數
     */
    public function __construct()
    {
        parent::__construct();
    }
    /**
     * 默認索引頁
     */
    public function index()
    {
        $this->display();
    }
    /**
     * 提交處理
     */
    public function parse()
    {
       /**
        * $_FILES數組說明
        * array(n) {
        *   ["表單文件框名稱"] => array(5) {
        *       ["name"]        => 提交文件名稱
        *       ["type"]        => 提交文件類型 Excel為"application/vnd.ms-excel"
        *       ["tmp_name"]    => 臨時文件名稱
        *       ["error"]       => 錯誤(0成功1文件太大超過upload_max_filesize2文件太大超過MAX_FILE3上傳不完整4沒有上傳文件)
        *       ["size"]        => 文件大小(單位:KB)
        *   }
        * }
        */
        $return=array(0,'');
        /**
         * 判斷是否提交
         * is_uploaded_file(文件名稱)用於確定指定的文件是否使用POST方法上傳,防止非法提交,通常和move_upload_file一起使用保存上傳文件到指定的路徑
         */
        if(!isset($_FILES) || !is_uploaded_file($_FILES['excel']['tmp_name']))
        {
            $return=array(1,'提交不合法');
        }
        //處理
        if(0 == $return[0])
        {
            import('@.Util.ExcelParser');
            $excel=new ExcelParser($_FILES['excel']['tmp_name']);
            $return=$excel->main();
        }
        //輸出處理
        print_r($return);
    }
}
?>
[/php]

處理類
[php]
<?php
/**
* CopyRight (c) 2009,
* All rights reserved.
* 文件名:excel數據獲取
* 摘  要:
*
* @author 星期八 [email protected]
* @version 0.1
*/
class ExcelParser
{
    private $_data=array(0,'');
    private $_excel_handle;
    private $_excel=array();
    /**
     * 構造函數
     * @param <string> $filename 上傳文件臨時文件名稱
     */
    public function __construct($filename)
    {
        /**
         * 引入excelparser類
         * 普通方法為
         * requires 路徑.'excelparser.php';
         * import為ThinkPHP自帶導入類方法
         */
        import('@.Util.PHPExcelParser.excelparser','','.php');
        $this->_excel_handle=new ExcelFileParser();
        //錯誤獲取
        $this->checkErrors($filename);
    }
    /**
     * 錯誤校驗
     */
    private function checkErrors($filename)
    {
        /**
         * 方法一
         */
        $error_code=$this->_excel_handle->ParseFromFile($filename);
        /**
         * 方法二
         * $file_handle = fopen($this->_filename,'rb');
         * $content = fread($file_handle,filesize($this->_filename));
         * fclose($file_handle);
         * $error_code = $this->_excel->ParseFromString($content);
         * unset($content,$file_handle);
         */
        switch($error_code)
        {
            case 0:
                //無錯誤不處理
                break;
            case 1:
                $this->_data=array(1,'文件讀取錯誤(Linux注意讀寫權限)');
                break;
            case 2:
                $this->_data=array(1,'文件太小');
                break;
            case 3:
                $this->_data=array(1,'讀取Excel表頭失敗');
                break;
            case 4:
                $this->_data=array(1,'文件讀取錯誤');
                break;
            case 5:
                $this->_data=array(1,'文件可能為空');
                break;
            case 6:
                $this->_data=array(1,'文件不完整');
                break;
            case 7:
                $this->_data=array(1,'讀取數據錯誤');
                break;
            case 8:
                $this->_data=array(1,'版本錯誤');
                break;
        }
        unset($error_code);
    }
    /**
     * Excel信息獲取
     */
    private function getExcelInfo()
    {
        if(1==$this->_data[0])return;
        /**
         * 獲得sheet數量
         * 獲得sheet單元對應的行和列
         */
        $this->_excel['sheet_number']=count($this->_excel_handle->worksheet['name']);
        for($i=0;$i<$this->_excel['sheet_number'];$i++)
        {
            /**
             * 行於列
             * 注意:從0開始計數
             */
            $row=$this->_excel_handle->worksheet['data'][$i]['max_row'];
            $col=$this->_excel_handle->worksheet['data'][$i]['max_col'];
            $this->_excel['row_number'][$i]=($row==NULL)?0:++$row;
            $this->_excel['col_number'][$i]=($col==NULL)?0:++$col;
            unset($row,$col);
        }
    }
    /**
     * 中文處理函數
     * @return <string>
     */
    private function uc2html($str)
    {
        $ret = '';
        for( $i=0; $i<strlen($str)/2; $i++ )
        {
            $charcode = ord($str[$i*2])+256*ord($str[$i*2+1]);
            $ret .= '&#'.$charcode.';';
        }
        return mb_convert_encoding($ret,'UTF-8','HTML-ENTITIES');
    }
    /**
     * Excel數據獲取
     */
    private function getExcelData()
    {
        if(1==$this->_data[0])return;

        //修改標記
        $this->_data[0]=1;
        //獲取數據
        for($i=0;$i<$this->_excel['sheet_number'];$i++)
        {
            /**
             * 對行循環
             */
            for($j=0;$j<$this->_excel['row_number'][$i];$j++)
            {
                /**
                 * 對列循環
                 */
                for($k=0;$k<$this->_excel['col_number'][$i];$k++)
                {
                    /**
                     * array(4) {
                     *   ["type"]   => 類型 [0字符類型1整數2浮點數3日期]
                     *   ["font"]   => 字體
                     *   ["data"]   => 數據
                     *   ...
                     * }
                     */
                    $data=$this->_excel_handle->worksheet['data'][$i]['cell'][$j][$k];
                    switch($data['type'])
                    {
                        case 0:
                            //字符類型
                            if($this->_excel_handle->sst['unicode'][$data['data']])
                            {
                                //中文處理
                                $data['data'] = $this->uc2html($this->_excel_handle->sst['data'][$data['data']]);
                            }
                            else
                            {
                                $data['data'] = $this->_excel_handle->sst['data'][$data['data']];
                            }
                            break;
                        case 1:
                            //整數
                            //TODO
                            break;
                        case 2:
                            //浮點數
                            //TODO
                            break;
                        case 3:
                            //日期
                            //TODO
                            break;
                    }
                    $this->_data[1][$i][$j][$k]=$data['data'];
                    unset($data);
                }
            }
        }
    }
    /**
     * 主函數
     * @return <array> array(標識符,內容s)
     */
    public function main()
    {
        //Excel信息獲取
        $this->getExcelInfo();
        //Excel數據獲取
        $this->getExcelData();
        return $this->_data;
    }
}

?>


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved