最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

nodejs使用node-xlsx生成excel的方法示例

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 21:51:59
文檔

nodejs使用node-xlsx生成excel的方法示例

nodejs使用node-xlsx生成excel的方法示例:## 使用nodejs中node-xlsx庫進(jìn)行excel的生成操作 ## 近日,應(yīng)領(lǐng)導(dǎo)要求,從網(wǎng)上抓了一大批數(shù)據(jù)存入了數(shù)據(jù)庫,可是媽媽批 ,市場妹子要的是excel表格啊,畢竟妹子的話還是要聽的(關(guān)鍵人家語氣蠻好的),就從網(wǎng)上查一些資料??墒遣閬聿槿グl(fā)現(xiàn)很多都是復(fù)制粘貼
推薦度:
導(dǎo)讀nodejs使用node-xlsx生成excel的方法示例:## 使用nodejs中node-xlsx庫進(jìn)行excel的生成操作 ## 近日,應(yīng)領(lǐng)導(dǎo)要求,從網(wǎng)上抓了一大批數(shù)據(jù)存入了數(shù)據(jù)庫,可是媽媽批 ,市場妹子要的是excel表格啊,畢竟妹子的話還是要聽的(關(guān)鍵人家語氣蠻好的),就從網(wǎng)上查一些資料??墒遣閬聿槿グl(fā)現(xiàn)很多都是復(fù)制粘貼

## 使用nodejs中node-xlsx庫進(jìn)行excel的生成操作 ##

近日,應(yīng)領(lǐng)導(dǎo)要求,從網(wǎng)上抓了一大批數(shù)據(jù)存入了數(shù)據(jù)庫,可是媽媽批 ,市場妹子要的是excel表格啊,畢竟妹子的話還是要聽的(關(guān)鍵人家語氣蠻好的),就從網(wǎng)上查一些資料??墒遣閬聿槿グl(fā)現(xiàn)很多都是復(fù)制粘貼,說實(shí)話真的討厭這樣行為,代碼好歹你自己先跑跑,加點(diǎn)注釋,有些人的代碼你確定你自己跑過? 就發(fā)到網(wǎng)上坑人,各種耽誤別人的時間。

nodejs中生成excel的庫很多,在嘗試后,個人認(rèn)為對于簡單的需求(按行添加),使用node-xlsx就足夠了。

1.因?yàn)閷儆诘谌侥K,所以肯定要npm一下,然后引入。

npm install node-xlsx;
npm install fs

2.在代碼中引入模塊;

const xlsx = require('node-xlsx')//引入模塊
import * as fs from 'fs'

3.下面上關(guān)鍵代碼;

 數(shù)據(jù)填充
 sqlite.queryData("select * from personInfo",(rows)=>{
 //rows是個從數(shù)據(jù)庫里面讀出來的數(shù)組,大家就把他當(dāng)成一個普通的數(shù)組就ok
 let data = [] // 其實(shí)最后就是把這個數(shù)組寫入excel 
 let title = ['id','name','address','fansCount','tag','label','price0','price1']//這是第一行 俗稱列名 
 data.push(title) // 添加完列名 下面就是添加真正的內(nèi)容了
 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ù)組,可以將對象的值分解添加進(jìn)數(shù)組,例如:['1','name','上海']
 });
 this.writeXls(data)
 })
 
 
先說一下title 這個數(shù)組就是excel中的第一行數(shù)據(jù),就是列名,用來描述的。算了,我還是上圖解釋吧
![就是表頭]

表頭完了,下面插入數(shù)據(jù),

簡單的解釋,這個data是個二維數(shù)組,它里面的每個數(shù)組代表著一行的數(shù)據(jù),所以大家添加的時候一定要對應(yīng)上。添加的每個數(shù)組長度要相同(data中一定要添加數(shù)組啊,切記)  

你添加了幾個數(shù)組,在生成的excel中內(nèi)容就會有多少行的數(shù)據(jù),假如我上面的rows數(shù)組長度是3那么我生成的excel中內(nèi)容的數(shù)據(jù)就是三行(說到這里大家明白了嗎,表述不行,急死我了)。  

當(dāng)我們把data填充數(shù)據(jù)填充完畢后,就開始下一步,進(jìn)行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),他是有權(quán)限修改文件的,不像瀏覽器,瀏覽器是無權(quán)默認(rèn)修改文件的,你想想你正在打開瀏覽器,它就把你的電腦里的內(nèi)容都修改沒了,或者偷偷上傳這是多么可怕的事情,所以瀏覽器的功能還是被限制了很多很多的,以前做安卓生成這些也是麻煩的很,現(xiàn)在真的該感謝一下nodejs用的很爽。喜歡的話,請點(diǎn)贊評論哦 ,作者真正意義的第一篇博客。

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

nodejs使用node-xlsx生成excel的方法示例

nodejs使用node-xlsx生成excel的方法示例:## 使用nodejs中node-xlsx庫進(jìn)行excel的生成操作 ## 近日,應(yīng)領(lǐng)導(dǎo)要求,從網(wǎng)上抓了一大批數(shù)據(jù)存入了數(shù)據(jù)庫,可是媽媽批 ,市場妹子要的是excel表格啊,畢竟妹子的話還是要聽的(關(guān)鍵人家語氣蠻好的),就從網(wǎng)上查一些資料??墒遣閬聿槿グl(fā)現(xiàn)很多都是復(fù)制粘貼
推薦度:
標(biāo)簽: excel 使用方法 excel表格
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top