简体   繁体   English

反应中的 Xlsx sheetname 长度超过 31 个字符

[英]Xlsx sheetname exceeding 31 characters in length in react

I'm using react to get table data from database and exporting it as excel and making the title of excel as tablename.我正在使用 react 从数据库中获取表数据并将其导出为 excel 并将 excel 的标题作为表名。 But I'm facing and issue if the excel file name is exceeding 31 characters, sheet is not getting downloaded.但是如果 excel 文件名超过 31 个字符,我将面临问题,则无法下载工作表。 And throwing below error in browser console output.并在浏览器控制台 output 中抛出错误。

Uncaught Error: Sheet names cannot exceed 31 chars

Here is my code below这是我下面的代码

var workbook=XLSX.utils.book_new();
workbook.SheetNames.push(title); //title: tablename
var workSheet=XLSX.utils.aoa_to_sheet(tableData); //tableData: data from Database
workbook.Sheets[title]=workSheet;
var output=XLSX.write(workbook, {bookType:'xlsx', type:'binary'});
function s2ab(s) {
  var buf = new ArrayBuffer(s.length);
  var view = new Uint8Array(buf);
  for (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
  return buf;
}
saveAs(new Blob([s2ab(output)], {type:"application/octet-stream"}), title + '.xlsx');

Edit: I don't want to change the sheetname.编辑:我不想更改工作表名称。 Just wanted react to download even if sheetnames exceeding 31 characters即使工作表名称超过 31 个字符,也只想对下载做出反应

Solved by doing following changes通过进行以下更改解决

var workbook=XLSX.utils.book_new();
//workbook.SheetNames.push(title); //title: tablename
var workSheet=XLSX.utils.aoa_to_sheet(tableData); //tableData: data from Database
//workbook.Sheets[title]=workSheet;
XLSX.utils.book_append_sheet(workbook, workSheet, "Test"); // This line solve the problem
var output=XLSX.write(workbook, {bookType:'xlsx', type:'binary'});
function s2ab(s) {
  var buf = new ArrayBuffer(s.length);
  var view = new Uint8Array(buf);
  for (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
  return buf;
}
saveAs(new Blob([s2ab(output)], {type:"application/octet-stream"}), title + '.xlsx');

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM