簡體   English   中英

使用php和phpexcel從兩個表中導出mysql數據到excel

[英]export mysql data from two tables to excel using php and phpexcel

我正在嘗試從mysql表獲取數據並輸出到單個excel文件。 數據需要並排。

但是輸出的excel文件僅包含特殊字符,而不是mysql數據。 請指出正確的方向。

這是我的代碼:

<?php
    // connection with the database 
    $dbhost = "localhost"; 
    $dbuser = "root"; 
    $dbpass = "redhat"; 
    $dbname = "was"; 

    mysql_connect($dbhost,$dbuser,$dbpass); 
    mysql_select_db($dbname); 

    // require the PHPExcel file 
    require 'phpexcel/Classes/PHPExcel.php'; 
    //$q2 = "SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = ".$dbname."";
    $sql = "SHOW TABLES"; $res = mysql_query($sql); $num_tables = mysql_num_rows($res);
    $table = $num_tables;
    $i = 1;
    echo $i;
    echo $table;
    // write all table names with a variable value like table1 table2 table3
    // simple query 
    while($i <= $table){
        //$query = "SELECT servicedate,recdate,dostoreclag,casesrec,scandate,casesentered,casespending,casecountdiff,entrydate,rcvdtolag FROM hos1report ORDER by id DESC"; 
        $query = "SELECT servicedate,recdate,dostoreclag,casesrec,scandate,casesentered,casespending,casecountdiff,entrydate,rcvdtolag FROM hos".$i."report"; 
        $headings = array('Service Date','Rec. Date','DOS to Rec. Lag','Cases Rec.','scan Date','Cases Entered','Cases Pending','Cases Count Diff','Entry Date','Rec. to Entry Lag'); 

        if ($result = mysql_query($query) or die(mysql_error())) { 
            // Create a new PHPExcel object 
            $objPHPExcel = new PHPExcel(); 
            $objPHPExcel->getActiveSheet()->setTitle('Report'); 

            $rowNumber = 8; 
            if ($i == 1) {
                $col = 'A';
            } elseif ($i == 2) {
                $col = 'L';
            } 
            //  $col = 'A'; 
            foreach($headings as $heading) { 
                $objPHPExcel->getActiveSheet()->setCellValue($col.$rowNumber,$heading); 
                $col++; 
            } 

            // Loop through the result set 
            $rowNumber = 9; 
            while ($row = mysql_fetch_row($result)) {
                if ($i == 1) {
                    $col = 'A';
                } elseif ($i == 2) {
                    $col = 'L';
                } 
                //  $col = 'A'; 
                //       $col = 'A'; 
                foreach($row as $cell) { 
                    $objPHPExcel->getActiveSheet()->setCellValue($col.$rowNumber,$cell); 
                    $col++; 
                }
                $rowNumber++; 

            } 
            // Freeze pane so that the heading line won't scroll 

            $objPHPExcel->getActiveSheet()->freezePane('A2'); 
            // Save as an Excel BIFF (xls) file 
            $i++;
        }
        $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); 

        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="report.xls"');
        header('Cache-Control: max-age=0'); 
    }

    $objWriter->save('php://output'); 
    exit(); 
    echo 'a problem has occurred... no data retrieved from the database'; 

?> 

試試這個代碼:

<?php
    // connection with the database 
    $dbhost = "localhost"; 
    $dbuser = "root"; 
    $dbpass = "redhat"; 
    $dbname = "was"; 

    mysql_connect($dbhost,$dbuser,$dbpass); 
    mysql_select_db($dbname); 

    // require the PHPExcel file 
    require 'phpexcel/Classes/PHPExcel.php'; 
    //$q2 = "SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = ".$dbname."";
    $sql = "SHOW TABLES"; $res = mysql_query($sql); $num_tables = mysql_num_rows($res);
    $table = $num_tables;
    $i = 1;
    echo $i;
    echo $table;
    // write all table names with a variable value like table1 table2 table3
    // simple query 
    while($i <= $table){
        //$query = "SELECT servicedate,recdate,dostoreclag,casesrec,scandate,casesentered,casespending,casecountdiff,entrydate,rcvdtolag FROM hos1report ORDER by id DESC"; 
        $query = "SELECT servicedate,recdate,dostoreclag,casesrec,scandate,casesentered,casespending,casecountdiff,entrydate,rcvdtolag FROM hos".$i."report"; 
        $headings = array('Service Date','Rec. Date','DOS to Rec. Lag','Cases Rec.','scan Date','Cases Entered','Cases Pending','Cases Count Diff','Entry Date','Rec. to Entry Lag'); 

        if ($result = mysql_query($query) or die(mysql_error())) { 
            // Create a new PHPExcel object 
            $objPHPExcel = new PHPExcel(); 
            $objPHPExcel->getActiveSheet()->setTitle('Report'); 

            $rowNumber = 8; 
            if ($i == 1) {
                $col = 'A';
            } elseif ($i == 2) {
                $col = 'L';
            } 
            //  $col = 'A'; 
            foreach($headings as $heading) { 
                $objPHPExcel->getActiveSheet()->setCellValue($col.$rowNumber,$heading); 
                $col++; 
            } 

            // Loop through the result set 
            $rowNumber = 9; 
            while ($row = mysql_fetch_row($result)) {
                if ($i == 1) {
                    $col = 'A';
                } elseif ($i == 2) {
                    $col = 'L';
                } 
                //  $col = 'A'; 
                //       $col = 'A'; 
                foreach($row as $cell) { 
                    $objPHPExcel->getActiveSheet()->setCellValue($col.$rowNumber,$cell); 
                    $col++; 
                }
                $rowNumber++; 

            } 
            // Freeze pane so that the heading line won't scroll 

            $objPHPExcel->getActiveSheet()->freezePane('A2'); 
            // Save as an Excel BIFF (xls) file 
            $i++;
        }
        // $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); 

        // header('Content-Type: application/vnd.ms-excel');
        // header('Content-Disposition: attachment;filename="report.xls"');
        // header('Cache-Control: max-age=0'); 

    }
        // Instantiate a Writer to create an OfficeOpenXML Excel .xlsx file
        $objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel); 
        // Write the Excel file to filename some_excel_file.xlsx in the current directory
        $objWriter->save('some_excel_file.xlsx');


    // $objWriter->save('php://output'); 
    exit(); 
    echo 'a problem has occurred... no data retrieved from the database';
?> 

希望它運行良好... :)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM