溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么在nodejs中利用node-xlsx生成一個(gè)excel文件

發(fā)布時(shí)間:2021-04-06 17:38:11 來(lái)源:億速云 閱讀:475 作者:Leah 欄目:web開發(fā)

怎么在nodejs中利用node-xlsx生成一個(gè)excel文件?相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

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是個(gè)從數(shù)據(jù)庫(kù)里面讀出來(lái)的數(shù)組,大家就把他當(dāng)成一個(gè)普通的數(shù)組就ok
   let data = [] // 其實(shí)最后就是把這個(gè)數(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ù)組,可以將對(duì)象的值分解添加進(jìn)數(shù)組,例如:['1','name','上海']
   });
   this.writeXls(data)
  })
  
 
先說(shuō)一下title 這個(gè)數(shù)組就是excel中的第一行數(shù)據(jù),就是列名,用來(lái)描述的。算了,我還是上圖解釋吧
![就是表頭]

怎么在nodejs中利用node-xlsx生成一個(gè)excel文件

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

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

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

當(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,相信也沒(méi)什么好說(shuō)的了,這就是簡(jiǎn)單的生成excel的操作了

看完上述內(nèi)容,你們掌握怎么在nodejs中利用node-xlsx生成一個(gè)excel文件的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI