with descargar data javascript html excel html-table

descargar - HTML Table to Excel Javascript



table html to excel (2)

Estoy intentando usar este script para guardar una tabla html en un archivo de Excel, y funciona bien, sin embargo, no aparece en el nombre propio, sino en una cadena aleatoria. Y no puedo ver por qué.

Lo llamo con:

<input type="button" onclick="tableToExcel(''tablename'', ''name'')" value="Export to Excel">

código

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) { if (!table.nodeType) table = document.getElementById(table) var ctx = {worksheet: name || ''Worksheet'', table: table.innerHTML} window.location.href = uri + base64(format(template, ctx)) } })()


Las 3 líneas de código anteriores no funcionan en mi caso, pero aquí lo que encontré y espero que pueda ayudar.

function tableToExcel(table, name, filename) { let 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"><title></title><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]--><meta http-equiv="content-type" content="text/plain; charset=UTF-8"/></head><body><table>{table}</table></body></html>'', base64 = function(s) { return window.btoa(decodeURIComponent(encodeURIComponent(s))) }, format = function(s, c) { return s.replace(/{(/w+)}/g, function(m, p) { return c[p]; })} if (!table.nodeType) table = document.getElementById(table) var ctx = {worksheet: name || ''Worksheet'', table: table.innerHTML} var link = document.createElement(''a''); link.download = filename; link.href = uri + base64(format(template, ctx)); link.click(); }

<!DOCTYPE html> <html> <head> <style> table { font-family: arial, sans-serif; border-collapse: collapse; width: 100%; } td, th { border: 1px solid #dddddd; text-align: left; padding: 8px; } tr:nth-child(even) { background-color: #dddddd; } </style> </head> <body> <input type="button" onclick="tableToExcel(''myTable'', ''name'', ''myfile.xls'')" value="Export to Excel" > <table id="myTable"> <tr> <th>Company</th> <th>Contact</th> <th>Country</th> </tr> <tr> <td>Alfreds Futterkiste</td> <td>Maria Anders</td> <td>Germany</td> </tr> <tr> <td>Centro comercial Moctezuma</td> <td>Francisco Chang</td> <td>Mexico</td> </tr> <tr> <td>Ernst Handel</td> <td>Roland Mendel</td> <td>Austria</td> </tr> <tr> <td>Island Trading</td> <td>Helen Bennett</td> <td>UK</td> </tr> <tr> <td>Laughing Bacchus Winecellars</td> <td>Yoshi Tannamuri</td> <td>Canada</td> </tr> <tr> <td>Magazzini Alimentari Riuniti</td> <td>Giovanni Rovelli</td> <td>Italy</td> </tr> </table> </body> </html>


Puede usar el atributo de download soportado por el navegador moderno para a elemento de anclaje. Primero modifique su HTML agregando un ancla invisible:

<a id="dlink" style="display:none;"></a> <input type="button" onclick="tableToExcel(''tablename'', ''name'', ''myfile.xls'')" value="Export to Excel">

Observe también que la llamada a function tableToExcel ahora tiene el tercer parámetro, donde especifica el nombre del archivo.

Ahora usa este código modificado de tu función original:

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(); } })()

Observe las últimas 3 líneas de código: en lugar de asignar URL a la ventana, lo asignan al nuevo delimitador, luego usan un nuevo atributo de download para forzar la descarga como el nombre del archivo dado y luego el método de llamada simple click() del delimitador.

Darle una oportunidad.