nodejs使用node-xlsx生成excel的方法示例
## 使用nodejs中node-xlsx庫進行excel的生成操作 ##
近日,應領導要求,從網上抓了一大批數(shù)據(jù)存入了數(shù)據(jù)庫,可是媽媽批 ,市場妹子要的是excel表格啊,畢竟妹子的話還是要聽的(關鍵人家語氣蠻好的),就從網上查一些資料。可是查來查去發(fā)現(xiàn)很多都是復制粘貼,說實話真的討厭這樣行為,代碼好歹你自己先跑跑,加點注釋,有些人的代碼你確定你自己跑過? 就發(fā)到網上坑人,各種耽誤別人的時間。
nodejs中生成excel的庫很多,在嘗試后,個人認為對于簡單的需求(按行添加),使用node-xlsx就足夠了。
1.因為屬于第三方模塊,所以肯定要npm一下,然后引入。
npm install node-xlsx; npm install fs
2.在代碼中引入模塊;
const xlsx = require('node-xlsx')//引入模塊
import * as fs from 'fs'
3.下面上關鍵代碼;
數(shù)據(jù)填充
sqlite.queryData("select * from personInfo",(rows)=>{
//rows是個從數(shù)據(jù)庫里面讀出來的數(shù)組,大家就把他當成一個普通的數(shù)組就ok
let data = [] // 其實最后就是把這個數(shù)組寫入excel
let title = ['id','name','address','fansCount','tag','label','price0','price1']//這是第一行 俗稱列名
data.push(title) // 添加完列名 下面就是添加真正的內容了
rows.forEach((element) => {
let arrInner = []
arrInner.push(element.id)
arrInner.push(element.name)
arrInner.push(element.address)
arrInner.push(element.fansCount)
arrInner.push(element.tag)
arrInner.push(element.label)
arrInner.push(element.price0)
arrInner.push(element.price1)
data.push(arrInner)//data中添加的要是數(shù)組,可以將對象的值分解添加進數(shù)組,例如:['1','name','上海']
});
this.writeXls(data)
})
先說一下title 這個數(shù)組就是excel中的第一行數(shù)據(jù),就是列名,用來描述的。算了,我還是上圖解釋吧
![就是表頭]

表頭完了,下面插入數(shù)據(jù),
簡單的解釋,這個data是個二維數(shù)組,它里面的每個數(shù)組代表著一行的數(shù)據(jù),所以大家添加的時候一定要對應上。添加的每個數(shù)組長度要相同(data中一定要添加數(shù)組啊,切記)
你添加了幾個數(shù)組,在生成的excel中內容就會有多少行的數(shù)據(jù),假如我上面的rows數(shù)組長度是3那么我生成的excel中內容的數(shù)據(jù)就是三行(說到這里大家明白了嗎,表述不行,急死我了)。
當我們把data填充數(shù)據(jù)填充完畢后,就開始下一步,進行excel的生成。
2.生成excel
private writeXls(datas) {
let buffer = xlsx.build([
{
name:'sheet1',
data:datas
}
]);
fs.writeFileSync('./the_content.xlsx',buffer,{'flag':'w'});//生成excel the_content是excel的名字,大家可以隨意命名
}
這些都是api,相信也沒什么好說的了,這就是簡單的生成excel的操作了
備注:
這是nodejs操作文件,可能有些不熟悉的會入坑,nodejs是個后臺系統(tǒng),他是有權限修改文件的,不像瀏覽器,瀏覽器是無權默認修改文件的,你想想你正在打開瀏覽器,它就把你的電腦里的內容都修改沒了,或者偷偷上傳這是多么可怕的事情,所以瀏覽器的功能還是被限制了很多很多的,以前做安卓生成這些也是麻煩的很,現(xiàn)在真的該感謝一下nodejs用的很爽。喜歡的話,請點贊評論哦 ,作者真正意義的第一篇博客。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
基于Express和Multer實現(xiàn)文件本地服務器文件上傳功能
在現(xiàn)代應用程序中,文件上傳功能成為了用戶共享和存儲數(shù)據(jù)的重要途徑,所以本文我們一起來探討文件上傳中間件的重要性,并提供常見的實現(xiàn)方法和相應的代碼吧2023-06-06
Node.js(v16.13.2版本)安裝及環(huán)境配置的圖文教程
本文主要介紹了Node.js(v16.13.2版本)安裝及環(huán)境配置的圖文教程,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-05-05

