jquery export table to excel以指数形式更改值

时间:2013-12-19 05:25:36

标签: javascript jquery excel

我有一个jquery导出表来excel代码。但问题是它改变了xls的导出文件的值。当我导出它时,我的表td的值为810101E001,它会像8.10E + 06那样更改值。

请给我解决方案现在该做什么。

http://jsfiddle.net/wVejP/773/

jquery代码是

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

1 个答案:

答案 0 :(得分:0)

你不是真的从我看到的表中将表导出到Excel,你将它导出到Excel内的HTML(即它仍然被编码为文件中的网页,并在保存/加载时收到警告) 。

在任何情况下,Excel都会将该字段解释为数字,为了阻止它这样做,您必须设置该单元格的样式以指示它是文本。但是,由于您没有将HTML转换为内部Excel XML语法,因此我不确定如何执行此操作(因为我认为这是正确的<Cell><ss:Data ss:Type="String" ...>...</Data></Cell>)。

因此,您需要将HTML完全转换为Excel XML,或者您可以引用所有单元格数据,例如:

contents = table.innerHTML
                .replace(/(<td[^>]*>)/gi, '$1"')
                .replace(/(<\/td[^>]*>)/gi, '"$1');

但是引用所有这也不好,理想情况下你想要某种方式将某些单元格标记为文本并引用它们 - 但如果你不能自动地这样做,你就像好吧,只需将引号放入HTML本身。如果您知道单元格的位置,那么只需引用单个单元格就可以这样做(在您的示例中,它是第一个TD,因此很容易)。

但实际上你需要将HTML转换为Excel XML来正确地执行此操作(您仍然需要知道哪些单元格不希望被解释为数字)。请参阅此答案,了解其中的起点:Converting excel spreadsheets to HTML