使用xlsx模块读取工作表的前n行

时间:2018-08-21 05:32:48

标签: javascript node.js xlsx

我正在尝试使用xlsx模块从Excel工作表中读取前五行数据。 最初,我尝试使用sheet_to_json方法将整个工作表数据转换为数组数组。

let sheetData = xlsx.utils.sheet_to_json(workbook.Sheets[sheetsList[i]], {
  header: 1,
  defval: '',
  blankrows: true
});

但是当文件很大时(在工作表中存在1万条记录),就会出现问题(内存不足)。

其次,我尝试使用以下链接:https://github.com/SheetJS/js-xlsx/issues/214#issuecomment-96843418 但是我收到以下错误:

    f:\xxx\node_modules\xlsx\xlsx.js:2774
function decode_range(range) { var x =range.split(":").map(decode_cell); return {s:x[0],e:x[x.length-1]}; }
                                            ^

TypeError: Cannot read property 'split' of undefined

我该如何解决?还是它们有其​​他可用的方法或模块,以便我可以从csv,xlsx,xls中获取数据?

谢谢!

1 个答案:

答案 0 :(得分:1)

可以使用存在的 sheetRows 选项获取工作表的前n行。

因此,代码如下:

let workbook = xlsx.readFile(path, {sheetRows: 5})
 let sheetsList = workbook.SheetNames
 let sheetData = xlsx.utils.sheet_to_json(workbook.Sheets[sheetsList[i]], {
      header: 1,
      defval: '',
      blankrows: true
 });

在这里,我仅限于前5行。

感谢所有尝试解决此问题的人。特别感谢xlsx社区成员。这是链接:https://github.com/SheetJS/js-xlsx/issues/1225