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

时间:2014-04-25 08:45:40

标签: php jquery pdf csv phpexcel

我的导出功能包含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文件并将其重复用于转换过程?

1 个答案:

答案 0 :(得分:0)

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