Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/476.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/batch-file/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript jquery将表导出到excel以指数形式更改值_Javascript_Jquery_Excel - Fatal编程技术网

Javascript jquery将表导出到excel以指数形式更改值

Javascript jquery将表导出到excel以指数形式更改值,javascript,jquery,excel,Javascript,Jquery,Excel,我有一个jquery导出表到excel的代码。但问题是它更改了xls的导出文件的值。我的表td的值为810101E001,当我导出它时,它会更改值,如8.10E+06 请告诉我现在该怎么办 jquery代码是 var tableToExcel = (function() { var uri = 'data:application/vnd.ms-excel;base64,' , template = '<html xmlns:o="urn:schemas-microsoft-c

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

请告诉我现在该怎么办

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))
  }
})()
var tableToExcel=(函数(){
var uri='data:application/vnd.ms excel;base64,'
,模板=“{table}”
,base64=函数{return window.btoa(unescape(encodeURIComponent))}
,format=函数(s,c){返回s.replace(/{(\w+)}/g,函数(m,p){返回c[p];})}
返回函数(表、名称){
如果(!table.nodeType)table=document.getElementById(table)
var ctx={工作表:名称| |'工作表',表:table.innerHTML}
window.location.href=uri+base64(格式(模板,ctx))
}
})()

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

在任何情况下,Excel都会将该字段解释为一个数字,为了阻止它这样做,您必须设置该单元格的样式以指示它是文本。但是,由于您没有将HTML转换为内部Excel XML语法,因此我不确定如何进行转换(无论如何,我认为这是正确的

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

contents = table.innerHTML
                .replace(/(<td[^>]*>)/gi, '$1"')
                .replace(/(<\/td[^>]*>)/gi, '"$1');
contents=table.innerHTML
.替换(/(]*>)/gi,$1“)
.替换(/(]*>)/gi,“$1”);
但这也会引用所有不好的内容,理想情况下,您需要某种方式将某些单元格标记为文本并引用它们——但如果您不能自动这样做,那么您也可以将这些引用放入HTML本身。如果您知道单元格的位置,您可以通过引用单个单元格(在您的示例中,它是第一个
TD
,因此很容易)

但实际上,您需要将HTML转换为Excel XML才能正确执行此操作(您仍然需要知道哪些单元格不希望被解释为数字)。请参见此答案,了解该问题的出发点: