天天看點

php 導出word格式的資料

大家也許對php導出excel格式資料的原理很熟悉了吧,但是excel格式的資料的格式很死不靈活的,使用者一定要導出word格式的資料  在技術經理的指導下,馬馬虎虎的寫了一個還算湊合的,以下是具體的程式代碼:

//  這是word 的類(不用改,直接拷貝過去建一個word的類檔案放在自己的公共的類檔案夾下)

class word

{

    function start()

    {

        ob_start();

        echo '<html xmlns:o="urn:schemas-microsoft-com:office:office"

        xmlns:w="urn:schemas-microsoft-com:office:word"

        xmlns="http://www.w3.org/TR/REC-html40">';

        }

    function save($path)

    {

        echo "</html>";

        $data = ob_get_contents();

        ob_end_clean();

        $this->wirtefile ($path,$data);

    }

    function wirtefile ($fn,$data)

    {

        $fp=fopen($fn,"wb");

        fwrite($fp,$data);

        fclose($fp);

    }

}

// 這裡是你  導出的程式檔案

//  導出   **********start**********

require SITE_ROOT.'include/word.class.php';  //   上面的類檔案我是放在 根目錄下的include檔案夾下

$word = new word();

// 查詢資料填入   word 中

                $result = $db->query("SELECT * FROM ".DB_PRE."box where status='9' order by boxid DESC");

                while($r = $db->fetch_array($result))

                {

                    $r['orderinfo'] = $db->get_one("SELECT * FROM ".DB_PRE."order where orderid='".$r['orderid']."'");

                    $r['wrapinfo']  = $db->get_one("SELECT * FROM ".DB_PRE."wrap where orderid='".$r['orderid']."'");

                    $boxlist[] = $r;

                }

                 foreach($boxlist as $key=>$val){

                     $order->UPCAbarcode($val['box_code']);

                     $html .='<table width=800 cellpadding="6" align="center" cellspacing="5" bgcolor="#000000">

                        <tr bgcolor="White" height="50">

                          <td width=80 style="border:1px solid #c8c8c8;">iGo運<br/>單号</td>

                          <td width=300 style="border:1px solid #c8c8c8;"><img src='.$val['iGocode_code'].' /><br/>&nbsp;&nbsp;'.$val['box_code'].'</td>

                          <td width=60 style="border:1px solid #c8c8c8;">日期</td>

                          <td width=100 style="border:1px solid #c8c8c8;">'.date('Y-m-d',$val[create_date]).'</td>

                          <td width=100 style="border:1px solid #c8c8c8;">标示<br/>姓名</td>

                          <td width=240 style="border:1px solid #c8c8c8;">'.$val[code].'/'.$val['orderid'].'<br/>'.$val['orderinfo']['user_name'].'</td>

                        </tr>

                        <tr bgcolor="White">

                          <td width=60 style="border:1px solid #c8c8c8;">件數</td>

                          <td width=40 style="border:1px solid #c8c8c8;">3</td>

                          <td width=40 style="border:1px solid #c8c8c8;">重量</td>

                          <td width=150 style="border:1px solid #c8c8c8;">56.5</td>

                          <td width=40 style="border:1px solid #c8c8c8;">品名</td>

                          <td width=390 style="border:1px solid #c8c8c8;">咬咬了,吸盤碗,學飲杯,魚幹油</td>

                        </tr>

                        <tr bgcolor="White">

                          <td width=110 style="border:1px solid #c8c8c8;">服務<br/>類别</td>

                          <td width=200 style="border:1px solid #c8c8c8;">庫房服務</td>

                          <td width=110 style="border:1px solid #c8c8c8;">服務<br/>要求</td>

                          <td width=280 style="border:1px solid #c8c8c8;">合小箱</td>

                        </tr>

                        <tr bgcolor="White">

                          <td width=120 style="border:1px solid #c8c8c8;"><br/><br/>客戶<br/>備注<br/><br/></td>

                          <td width=580 style="border:1px solid #c8c8c8;">'.$val['orderinfo']['beizhu'].'</td>

                        </tr>

                        <tr bgcolor="White">

                          <td width=120 style="border:1px solid #c8c8c8;"><br/><br/><br/>到貨<br/>情況<br/><br/><br/><br/></td>

                          <td width=580 style="border:1px solid #c8c8c8;">什麼問題?果點不到<br/>什麼問題?果點不到<br/>什麼問題?果點不到<br/><br/><br/><br/><br/><br/><br/><br/></td>

                        </tr>

                        </table> <br/><br/><br/><br/>

                    '; 

                 }

                $word->start();

                $filename = '揀貨單導出.doc';

                echo $html;

                 $word->save($filename);

                 //檔案的類型

                 header('Content-type: application/word');

                 header('Content-Disposition: attachment; filename="揀貨單導出.doc"');

                 readfile($filename);

                 ob_flush();

                 flush();

                exit();

             //  導出     **********end**********

//  好啦  運作一下 看看效果吧

繼續閱讀