保存Excel导出的文件&;将其转换为CSV或PDF


Save an Excel exported file & convert it into CSV or PDF

我有一个导出函数,其中包含excel、csv、pdf选项。对于excel选项,我已经使用此代码实现

var tableToExcel = (function() {
    var uri = 'data:application/vnd.ms-excel;base64,',
            template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>',
            base64 = function(s) {
        return window.btoa(unescape(encodeURIComponent(s)))
    }, format = function(s, c) {
        return s.replace(/{('w+)}/g, function(m, p) {
            return c[p];
        })
    }
    return function(table, name, filename) {
        if (!table.nodeType)
            table = document.getElementById(table)
        var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML}
        document.getElementById("dlink").href = uri + base64(format(template, ctx));
        document.getElementById("dlink").download = filename;
        document.getElementById("dlink").click();
    }
})()

结果是excel文件可以下载。然后,我想重用excel文件,使用phpexcel-lib将其转换为csv或pdf。但我不知道如何修改上面的代码,所以我会把excel保存在临时文件夹中,而不是用这个代码执行文件来生成pdf或csv。

<?php
require_once('PHPExcel/Classes/PHPExcel.php');
//Usage:
convertXLStoCSV('input.xls','output.csv');
function convertXLStoCSV($infile,$outfile)
{
    $fileType = PHPExcel_IOFactory::identify($infile);
    $objReader = PHPExcel_IOFactory::createReader($fileType);
    $objReader->setReadDataOnly(true);  
    $objPHPExcel = $objReader->load($infile);   
    $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'CSV');
    $objWriter->save($outfile);
}
?>

如何实现excel文件的临时保存并在转换过程中重复使用?

在尝试了一些方法后,我决定不使用上面的方法(制作一个临时excel文件,然后将其转换为csv),而是使用以前生成但保存在会话中的sql结果的直接csv转换机制。