我的导出功能包含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文件并将其重复用于转换过程?
答案 0 :(得分:0)
在我试过的一些方法之后,我决定不使用上面的方法(制作一个临时excel文件,然后将其转换为csv),但是使用之前生成的sql结果的直接csv转换机制但是保存了在会议中。