成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

原生php導(dǎo)出csv文件

antyiwei / 374人閱讀

摘要:附上結(jié)果圖片下圖為方法中導(dǎo)出的練習(xí)數(shù)據(jù),頭部引入除過都是封裝了的方法類,導(dǎo)出主要參考下面兩個(gè)方法。

require("./db/dbManager.php");
require("./session.php");
require("./department_utils.php");

class ExportCSV{
    function __construct(){
        $this->db=new dbManager();
        $this->out = fopen("php://output", "w");
    }
    
    function output(&$row){
        for($i=0;$iout,$row);
    }
    
    function user($opts){
        
        if(isset($opts["department"]) && $opts["department"]>0){
            $department=(int)$opts["department"];
            $name=$this->db->querySingle("SELECT DepartmentName FROM department WHERE ID=?",[$department]);
            if(!$name)
                return;
            $fileName=$name."-用戶列表";
        }else{
            $department=0;
            $fileName="所有部門-用戶列表";
        }
        
        if(isset($opts["download"])){
            //header("Content-Disposition: attachment;filename="".$fileName.".csv"");
            $this->set_filename($fileName.".csv");
        }

        $h=["部門","用戶名","姓名","手機(jī)","工號","身份"];
        $this->output($h);
        $sql="SELECT COUNT(*) FROM users";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" WHERE DepartmentId IN ".$deps;
        }
        $total=$this->db->querySingle($sql);
        $sql="SELECT d.DepartmentName,u.Username,u.Name,u.Phone,u.empno,r.name FROM users u";
        $sql.=" LEFT JOIN department d ON d.ID=u.DepartmentId";
        $sql.=" LEFT JOIN role r ON r.id=u.role";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" WHERE DepartmentId IN ".$deps;
        }
        $sql.=" LIMIT ?,10";
        for($i=0;$i<$total;$i+=10){
            $arr=$this->db->queryAll($sql,[$i]);
            if(!$arr)
                break;
            for($j=0;$joutput($arr[$j]);
        }
    }
    
    function time_range($b,$e){
        return date("Ymd",$b)."-".date("Ymd",$e);
    }
    
    function exam($opts){
        if(isset($opts["department"]) && $opts["department"]>0){
            $department=(int)$opts["department"];
            $name=$this->db->querySingle("SELECT DepartmentName FROM department WHERE ID=?",[$department]);
            if(!$name)
                return;
        }else{
            $department=0;
            $name="所有部門";
        }
        $begin=(int)$opts["begin"];
        $end=(int)$opts["end"];
        $begin_str=date("Y-m-d H:i:s",$begin);
        $end_str=date("Y-m-d H:i:s",$end);
        
        $fileName=$name."-考試-".$this->time_range($begin,$end);
        if(isset($opts["download"])){
            //header("Content-Disposition: attachment;filename="".$fileName.".csv"");
            $this->set_filename($fileName.".csv");
        }
        
        $h=["部門","考試名","時(shí)間","時(shí)長(分鐘)","總分","及格線(百分制)"];
        $this->output($h);
        
        $sql="SELECT COUNT(*) FROM exam e";
        $sql.=" WHERE e.ExamTime BETWEEN ? AND ?";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" AND DepartmentId IN ".$deps;
        }
        $total=$this->db->querySingle($sql,[$begin_str,$end_str]);
        $sql="SELECT d.DepartmentName,e.ExamName,e.ExamTime,e.ExamDuration,e.Score,e.PassScore FROM exam e";
        $sql.=" LEFT JOIN department d ON d.ID=e.DepartmentId";
        $sql.=" WHERE e.ExamTime BETWEEN ? AND ?";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" AND DepartmentId IN ".$deps;
        }
        $sql.=" LIMIT ?,10";
        for($i=0;$i<$total;$i+=10){
            $arr=$this->db->queryAll($sql,[$begin_str,$end_str,$i]);
            if(!$arr)
                break;
            for($j=0;$joutput($arr[$j]);
            }
        }
    }
    
    function grade($opts){
        if(isset($opts["department"]) && $opts["department"]>0){
            $department=(int)$opts["department"];
            $name=$this->db->querySingle("SELECT DepartmentName FROM department WHERE ID=?",[$department]);
            if(!$name)
                return;
        }else{
            $department=0;
            $name="所有部門";
        }
        $begin=(int)$opts["begin"];
        $end=(int)$opts["end"];
        $begin_str=date("Y-m-d H:i:s",$begin);
        $end_str=date("Y-m-d H:i:s",$end);
        
        $fileName=$name."-考試成績-".$this->time_range($begin,$end);
        if(isset($opts["download"])){
            //header("Content-Disposition: attachment;filename="".$fileName.".csv"");
            $this->set_filename($fileName.".csv");
        }
        
        $h=["部門","名字","考試名","時(shí)間","總分","分?jǐn)?shù)"];
        $this->output($h);

        $sql="SELECT COUNT(*) FROM grade g";
        $sql.=" LEFT JOIN exam e ON e.ID=g.ExamId";
        $sql.=" LEFT JOIN users u ON u.ID=g.UserId";
        $sql.=" WHERE e.ExamTime BETWEEN ? AND ?";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" AND u.DepartmentId IN ".$deps;
        }
        
        $total=$this->db->querySingle($sql,[$begin_str,$end_str]);
        $sql="SELECT d.DepartmentName,u.Name,e.ExamName,e.ExamTime,e.Score,g.Score FROM grade g";
        $sql.=" LEFT JOIN exam e ON e.ID=g.ExamId";
        $sql.=" LEFT JOIN users u ON u.ID=g.UserId";
        $sql.=" LEFT JOIN department d ON d.ID=u.DepartmentId";
        $sql.=" WHERE e.ExamTime BETWEEN ? AND ?";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" AND u.DepartmentId IN ".$deps;
        }
        $sql.=" LIMIT ?,10";
        for($i=0;$i<$total;$i+=10){
            $arr=$this->db->queryAll($sql,[$begin_str,$end_str,$i]);
            if(!$arr)
                break;
            for($j=0;$joutput($arr[$j]);
            }
        }
    }
    
    function exercise($opts){
        if(isset($opts["department"]) && $opts["department"]>0){
            $department=(int)$opts["department"];
            $name=$this->db->querySingle("SELECT DepartmentName FROM department WHERE ID=?",[$department]);
            if(!$name)
                return;
        }else{
            $department=0;
            $name="所有部門";
        }
        $begin=(int)$opts["begin"];
        $end=(int)$opts["end"];
        
        $fileName=$name."-練習(xí)數(shù)據(jù)-".$this->time_range($begin,$end);
        if(isset($opts["download"])){
            //header("Content-Disposition: attachment;filename="".$fileName.".csv"");
            $this->set_filename($fileName.".csv");
        }
        
        if(!$this->db->exec("ATTACH DATABASE "exercise.db.php" AS "EX""))
            return;
        $sql="SELECT COUNT(*) FROM EX.exercise e";
        $sql.=" LEFT JOIN users u ON u.ID=e.uid";
        $sql.=" WHERE e.time BETWEEN $begin AND $end";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" AND u.DepartmentId IN ".$deps;
        }
        $total=$this->db->querySingle($sql);
        
        $h=["部門","身份","名字","時(shí)間","結(jié)果"];
        $this->output($h);
        
        $sql="SELECT d.DepartmentName,r.name,u.Name,datetime(e.Time,"unixepoch","localtime"),e.result FROM EX.exercise e";
        $sql.=" LEFT JOIN users u ON u.ID=e.uid";
        $sql.=" LEFT JOIN department d ON d.ID=u.DepartmentId";
        $sql.=" LEFT JOIN role r ON r.ID=u.role";
        $sql.=" WHERE e.time BETWEEN $begin AND $end";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" AND u.DepartmentId IN ".$deps;
        }
        $sql.=" ORDER BY e.time ASC LIMIT ?,10";
        for($i=0;$i<$total;$i+=10){
            $arr=$this->db->queryAll($sql,[$i]);
            if(!$arr)
                break;
            for($j=0;$joutput($arr[$j]);
            }
        }
    }
    
    function set_filename($fileName){
        $userAgent=$_SERVER["HTTP_USER_AGENT"];
        if($userAgent && strstr($userAgent,"Firefox")){
            header("Content-Disposition: attachment;filename*=""."utf8""".urlencode($fileName).""");
        }else{
            header("Content-Disposition: attachment;filename="".urlencode($fileName).""");
        }
    }
    
    function study($opts){
        if(isset($opts["department"]) && $opts["department"]>0){
            $department=(int)$opts["department"];
            $name=$this->db->querySingle("SELECT DepartmentName FROM department WHERE ID=?",[$department]);
            if(!$name)
                return;
        }else{
            $department=0;
            $name="所有部門";
        }
        $begin=(int)$opts["begin"];
        $end=(int)$opts["end"];
        
        $fileName=$name."-學(xué)習(xí)時(shí)間-".$this->time_range($begin,$end);
        if(isset($opts["download"]))
            //header("Content-Disposition: attachment;filename="".$fileName.".csv"");
            $this->set_filename($fileName.".csv");
        
        $sql="SELECT COUNT(*) FROM studyRecord s";
        $sql.=" LEFT JOIN users u ON u.ID=s.UserId";
        $sql.=" WHERE s.Begin BETWEEN $begin AND $end";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" AND u.DepartmentId IN ".$deps;
        }
        $total=$this->db->querySingle($sql);
        
        $h=["部門","身份","名字","時(shí)間","時(shí)長(秒)","類型"];
        $this->output($h);
        
        $sql="SELECT d.DepartmentName,r.name,u.Name,datetime(s.Begin,"unixepoch","localtime"),s.Duration,s.Type FROM studyRecord s";
        $sql.=" LEFT JOIN users u ON u.ID=s.UserId";
        $sql.=" LEFT JOIN department d ON d.ID=u.DepartmentId";
        $sql.=" LEFT JOIN role r ON r.ID=u.role";
        $sql.=" WHERE s.Begin BETWEEN $begin AND $end";
        $sql.=" LIMIT ?,10";
        for($i=0;$i<$total;$i+=10){
            $arr=$this->db->queryAll($sql,[$i]);
            if(!$arr)
                break;
            for($j=0;$joutput($arr[$j]);
            }
        }
    }
    
    // 每個(gè)學(xué)員學(xué)習(xí)時(shí)間要按學(xué)習(xí)類型分組加起來
    function study2($opts){
        if(!$this->db->exec("ATTACH DATABASE "exercise.db.php" AS "EX""))
            return;

        if(isset($opts["department"]) && $opts["department"]>0){
            $department=(int)$opts["department"];
            $name=$this->db->querySingle("SELECT DepartmentName FROM department WHERE ID=?",[$department]);
            if(!$name)
                return;
        }else{
            $department=0;
            $name="所有部門";
        }
        $begin=(int)$opts["begin"];
        $end=(int)$opts["end"];
        
        $fileName=$name."-學(xué)習(xí)時(shí)間-".$this->time_range($begin,$end);
        if(isset($opts["download"]))
            $this->set_filename($fileName.".csv");
        
        $total=9999;
        
        $h=["部門","身份","名字","學(xué)習(xí)時(shí)間(秒)","練習(xí)時(shí)長(秒)","練習(xí)數(shù)量","練習(xí)正確數(shù)量","練習(xí)正確率"];
        $this->output($h);
        
        $sql="SELECT d.DepartmentName,r.name,u.Name,u.ID FROM users u";
        $sql.=" LEFT JOIN department d ON d.ID=u.DepartmentId";
        $sql.=" LEFT JOIN role r ON r.ID=u.role";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" WHERE u.DepartmentId IN ".$deps;
        }
        $sql.=" LIMIT ?,10";

        for($i=0;$i<$total;$i+=10){
            $arr=$this->db->queryAll($sql,[$i]);
            if(!$arr)
                break;
            for($j=0;$jdb->query("SELECT sum(-s.Duration*(s.Type-1)),sum(s.Duration*s.Type) FROM studyRecord s WHERE s.UserId=? AND s.Begin BETWEEN $begin AND $end",$uid);
                if($temp){
                    $arr[$j][]=(int)$temp[0];
                    $arr[$j][]=(int)$temp[1];
                }else{
                    $arr[$j][]=0;
                    $arr[$j][]=0;
                }
                $temp=$this->db->query("SELECT COUNT(*),SUM(e.result) FROM EX.exercise e WHERE e.uid=?",$uid);
                if($temp){
                    $arr[$j][]=(int)$temp[0];
                    $arr[$j][]=(int)$temp[1];
                    if($temp[0]>0){
                        $arr[$j][]=sprintf("%.2f",$temp[1]/$temp[0]);
                    }else{
                        $arr[$j][]=0;
                    }
                }
                $this->output($arr[$j]);
            }
        }
    }
    
    
    function get_libnames(){
        $sql="SELECT Name FROM question_lib group by Name";
        return $this->db->querySingleAll($sql);
    }

    function lib_error($opts){
        $begin=(int)$opts["begin"];
        $end=(int)$opts["end"];
        
        if(isset($opts["department"]) && $opts["department"]>0){
            $department=(int)$opts["department"];
            $name=$this->db->querySingle("SELECT DepartmentName FROM department WHERE ID=?",[$department]);
            if(!$name)
                return;
        }else{
            $department=0;
            $name="所有部門";
        }
        
        $fileName=$name."-高頻錯(cuò)題-".$this->time_range($begin,$end);
        if(isset($opts["download"]))
            $this->set_filename($fileName.".csv");
        
        $libs=$this->get_libnames();
        
        if(!$this->db->exec("ATTACH DATABASE "exercise.db.php" AS "EX""))
            return;
        
        $h=["題庫","題型","題目","選項(xiàng)","答案","答題數(shù)","答題正確數(shù)量","正確率"];
        $this->output($h);
        
        $sql="CREATE TEMP VIEW stat AS SELECT qid,count(*) as count,sum(result) as result,sum(result)*1.0/count(*)*1.0 as accuracy FROM EX.exercise";
        $sql.=" LEFT JOIN users u ON u.ID=uid";
        $sql.=" WHERE time BETWEEN $begin AND $end";
        if($department>0){
            $deps=department_with_child_sql($this->db,$department);
            $sql.=" AND u.DepartmentId IN ".$deps;
        }
        $sql.=" GROUP BY qid";
        $ret=$this->db->exec($sql);
        if(!$ret){
            return;
        }

        $sql="SELECT q.LibName,q.Type,q.Question,q.Option,q.Answer,s.count,s.result,s.accuracy FROM stat s";
        $sql.=" LEFT JOIN EX.question q ON q.ID=s.qid";
        $sql.=" WHERE q.LibName=?";
        $sql.=" AND s.count>=3";
        $sql.=" ORDER BY s.accuracy ASC";
        $sql.=" LIMIT 0,10";

        for($i=0;$idb->queryAll($sql,$libs[$i]);
            if(!$temp)
                continue;
            for($j=0;$joutput($temp[$j]);
            }
        }
    }
    
    //過關(guān)記錄
    function manmul_lib($opts){
        $begin=(int)$opts["begin"];
        $end=(int)$opts["end"];
        if(isset($opts["department"]) && $opts["department"]>0){
            $department=(int)$opts["department"];
            $name=$this->db->querySingle("SELECT DepartmentName FROM department WHERE ID=?",[$department]);
            if(!$name)
                return;
        }else{
            $department=0;
            $name="所有部門";
        }
        
        $fileName=$name."-過關(guān)記錄-".$this->time_range($begin,$end);
        if(isset($opts["download"]))
            $this->set_filename($fileName.".csv");
        
        $libs=$this->get_libnames();
        
        if(!$this->db->exec("ATTACH DATABASE "exercise.db.php" AS "EX""))
            return;
        
        $h=["姓名","部門","過關(guān)記錄","時(shí)間","難度系數(shù)"];
        $this->output($h);
        
    }
   
}


header("Content-Type: text/plain; charset=GB18030");
//header("Content-Type: application/octet-stream");

if(!isset($_GET["op"]))
    return;
$op=$_GET["op"];
if(!isset($_SESSION["AdminId"]))
    return;
$ec=new ExportCSV();
if(!department_can_admin($ec->db,$_GET["department"],$_SESSION["AdminId"]))
    return;

header("Cache-Control: max-age=0");

if($op=="user")
    $ec->user($_GET);
else if($op=="exam")
    $ec->exam($_GET);
else if($op=="grade")
    $ec->grade($_GET);
else if($op=="exercise")
    $ec->exercise($_GET);
else if($op=="study")
    $ec->study2($_GET);
else if($op=="libe")
    $ec->lib_error($_GET);
else if($op=="manmul")
    $ec->manmul_lib($_GET);

  
?>

一個(gè)模塊的代碼。附上結(jié)果圖片

下圖為study方法中導(dǎo)出的練習(xí)數(shù)據(jù),頭部引入除過session都是封裝了crud的db方法類,導(dǎo)出主要參考下面兩個(gè)方法。

方法:

function set_filename($fileName){
        $userAgent=$_SERVER["HTTP_USER_AGENT"];
        if($userAgent && strstr($userAgent,"Firefox")){
            header("Content-Disposition: attachment;filename*=""."utf8""".urlencode($fileName).""");
        }else{
            header("Content-Disposition: attachment;filename="".urlencode($fileName).""");
        }
    }

方法:

function output(&$row){
        for($i=0;$iout,$row);
    }
    

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/26073.html

相關(guān)文章

  • 原生php導(dǎo)出csv文件

    摘要:附上結(jié)果圖片下圖為方法中導(dǎo)出的練習(xí)數(shù)據(jù),頭部引入除過都是封裝了的方法類,導(dǎo)出主要參考下面兩個(gè)方法。 require(./db/dbManager.php); require(./session.php); require(./department_utils.php); class ExportCSV{ function __construct(){ $thi...

    yankeys 評論0 收藏0
  • PHP+MySQL導(dǎo)出大量數(shù)據(jù)(Iterator yield)

    摘要:開發(fā)中經(jīng)常遇到這樣的場景產(chǎn)品汪我要在后臺做一個(gè)功能,可以導(dǎo)出自定義時(shí)間范圍的訂單信息。結(jié)果,第二天一上班產(chǎn)品汪過來就是拍桌子,我想把去年一整年的訂單都導(dǎo)出來,結(jié)果后臺直接就掛了開發(fā)小哥一查,原來是內(nèi)存溢出了,一年下來的的訂單量足足有條。 開發(fā)中經(jīng)常遇到這樣的場景 產(chǎn)品汪:我要在后臺做一個(gè)功能,可以導(dǎo)出自定義時(shí)間范圍的訂單信息。開發(fā)小哥二話不說,半天就把功能做完并上線了。結(jié)果,第二天一上...

    codergarden 評論0 收藏0
  • 關(guān)于PHP導(dǎo)出CSV文件的實(shí)現(xiàn)過程以及一些經(jīng)常遇到的問題研究

    摘要:導(dǎo)出功能在管理后臺算是比較常見的了。但是如果用來打開,超過行的數(shù)據(jù)都會看不見,這是程序的問題。本次導(dǎo)出數(shù)據(jù)量很大。原因數(shù)值顯示精度為位造成精度丟失。 導(dǎo)出功能在管理后臺算是比較常見的了。在實(shí)現(xiàn)導(dǎo)出表格類信息的功能時(shí),可以選擇兩種實(shí)現(xiàn)方式: 導(dǎo)出為excel 導(dǎo)出為csv文件格式 用csv方式導(dǎo)出,則可以像導(dǎo)出txt一樣,以文本流的方式進(jìn)行流式處理,不但能導(dǎo)出海量信息,而且流式處理占...

    用戶83 評論0 收藏0
  • PHP高效導(dǎo)出Excel(CSV)

    摘要:,是逗號分隔值的英文縮寫,通常都是純文本文件。如果你導(dǎo)出的沒有什么高級用法的話,只是做導(dǎo)出數(shù)據(jù)用那么建議使用本方法要比要高效的多。二十萬數(shù)據(jù)導(dǎo)出大概需要到秒。 CSV,是Comma Separated Value(逗號分隔值)的英文縮寫,通常都是純文本文件。如果你導(dǎo)出的Excel沒有什么高級用法的話,只是做導(dǎo)出數(shù)據(jù)用那么建議使用本方法,要比PHPexcel要高效的多。二十萬數(shù)據(jù)導(dǎo)出大概...

    DoINsiSt 評論0 收藏0

發(fā)表評論

0條評論

antyiwei

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<