使用php和phpexcel从两个表中导出mysql数据到excel [英] export mysql data from two tables to excel using php and phpexcel

查看:66
本文介绍了使用php和phpexcel从两个表中导出mysql数据到excel的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试从mysql表获取数据并输出到单个excel文件.数据需要并排.

I am trying to get data from to mysql table and output to a single excel file. The data needs to come side-by-side.

但是输出的excel文件仅包含特殊字符,而不包含mysql数据.请为我指出正确的方向.

But the output excel file contains only special characters instead of mysql data. Please point me to the right direction.

这是我的代码:

<?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';
?> 

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

Hope it run well... :)

这篇关于使用php和phpexcel从两个表中导出mysql数据到excel的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆