如何使用nodejs读写excel文件

如何使用nodejs读写excel文件,第1张

nodejs作为功能强大的后端开发语言,有许多第三方包扩展nodejs能力。读写excel文件也有相关的第三方扩展。

本文介绍nodejs下如何通过使用node-xlsx扩展读写excel文件。

在nodejs的API文档中可以看到大部分的文件或者文件夹的读取 *** 作都有异步和同步两种 *** 作。

有这样一个需求,读取某个文件夹下面的所有文件,因为有文件夹的嵌套,所以需要使用递归来实现这一功能。

首先使用同步的方法,很简单的可以实现:

同步的逻辑很简单,每一个步骤都等上一步执行完再执行,没多大问题。

那么使用异步如何实现呢?

首先我想到的是,使用async/await去控制异步读取fs.readdir()的执行。

duang~报错~

这里报错的原因是:nodejs的fs模块的方法都没有返回promise。当然不能使用async/await进行处理。

在nodejs的fs模块的源码中,如下:

fs模块的readdir()和readdirSync()方法的核心区别是:readdirSync()方法直接返回的是通过binding.readdir()方法读取的结果。而readdir()方法则未返回任何值,只是将callback作为FSReqCallback对象onComplete方法,表示再读取成功之后再执行callback方法,从何获取到返回的读取内容。

可以看到fs.readdir()方法并没有返回promise,直接用await去修饰fs.readdir()方法,并不会同步化该方法中通过I/O去异步读取文件信息的 *** 作,这样的做法毫无意义。

所以,如何正确的使用异步读取的方法?

通过将fs.readdir()方法的返回promise化,这样就可以使用async/await了。

使用async/await事实上将后续的 *** 作阻塞了,需要等到readDir执行完之后再进行其他 *** 作,那么这里的和同步没有实质上的区别,反而还多了很多 *** 作,所以单单就readDir这里来说,将其promise化再使用async/await是无意义的。

但是这里在读取到files进行map的时候,里面的fs.stat()异步化,使用async/await是有意义的。这样可以不必等到 *** 作完了在进入下一次遍历,有利于提升效率。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/6040582.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-12
下一篇 2023-03-12

发表评论

登录后才能评论

评论列表(0条)

保存