jQuery 将表导出到 Excel 以指数形式更改值
jquery export table to excel changes the value in exponential form
我有一个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))
}
})()
从我所看到的情况来看,您并没有真正将表格导出到 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才能正确执行此操作(您仍然需要知道哪些单元格不想被解释为数字)。请参阅此答案以获取起点:将 Excel 电子表格转换为 HTML
相关文章:
- 将HTML表格导出到excel时,无法将数据加载到excel文件中
- 提交按钮,该按钮位于使用 Excel VBA 的 Javascript 中
- 将HTML表格导出到带有文本和图像的excel中
- 将JQuery Handontable保存到服务器上的excel文件中
- 使用Office.js在Excel中将20000多个单元格写入表失败
- 聚合物-dom重复的起始指数
- 如何处理javascript中的循环引用,类似于Excel提供迭代限制的方式
- 将Excel BLOB转换为javascript数组
- 生成的excel文件url
- 将表格下载到excel中,隐藏行带有ng重复
- 当数据从excel表中提取时,我想使用动态进度条
- Format for Excel VBA addWatermarkFromText
- CSV、PDF、Excel文件在dataTables的导出扩展中作为blob下载
- 使用JavaScript调用Excel文件
- CefSharp ChromiumWebBrowser javascript excel导出无法工作
- 将JSON数据格式化为excel文件
- Javascript表导出到excel utf8
- setInterval() 无法正常工作 - 呈指数级增长
- 通过简单的计算将Excel spreadhhet转换为在线网格
- jQuery 将表导出到 Excel 以指数形式更改值