欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年08月22日 14:17:07   作者:java_Android  
這篇文章主要介紹了nodejs使用node-xlsx生成excel,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

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

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

nodejs中生成excel的庫(kù)很多,在嘗試后,個(gè)人認(rèn)為對(duì)于簡(jiǎ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是個(gè)從數(shù)據(jù)庫(kù)里面讀出來(lái)的數(shù)組,大家就把他當(dāng)成一個(gè)普通的數(shù)組就ok
   let data = [] // 其實(shí)最后就是把這個(gè)數(shù)組寫(xiě)入excel 
   let title = ['id','name','address','fansCount','tag','label','price0','price1']//這是第一行 俗稱(chēng)列名 
   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)描述的。算了,我還是上圖解釋吧
![就是表頭]

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

簡(jiǎn)單的解釋?zhuā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ù)填充完畢后,就開(kāi)始下一步,進(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的操作了

備注:

這是nodejs操作文件,可能有些不熟悉的會(huì)入坑,nodejs是個(gè)后臺(tái)系統(tǒng),他是有權(quán)限修改文件的,不像瀏覽器,瀏覽器是無(wú)權(quán)默認(rèn)修改文件的,你想想你正在打開(kāi)瀏覽器,它就把你的電腦里的內(nèi)容都修改沒(méi)了,或者偷偷上傳這是多么可怕的事情,所以瀏覽器的功能還是被限制了很多很多的,以前做安卓生成這些也是麻煩的很,現(xiàn)在真的該感謝一下nodejs用的很爽。喜歡的話,請(qǐng)點(diǎn)贊評(píng)論哦 ,作者真正意義的第一篇博客。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • socket.io學(xué)習(xí)教程之基礎(chǔ)介紹(一)

    socket.io學(xué)習(xí)教程之基礎(chǔ)介紹(一)

    socket.io提供了基于事件的實(shí)時(shí)雙向通訊,所以下面這篇文章主要介紹了關(guān)于socket.io的相關(guān)資料,主要介紹了學(xué)習(xí)socket.io的基礎(chǔ)知識(shí),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-04-04
  • Windows下安裝NodeJS的詳細(xì)步驟

    Windows下安裝NodeJS的詳細(xì)步驟

    這篇文章主要介紹了Windows下安裝NodeJS,本文分步驟通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • 淺談HTTP 緩存的那些事兒

    淺談HTTP 緩存的那些事兒

    HTTP 緩存機(jī)制作為 Web 應(yīng)用性能優(yōu)化的重要手段,是想要成為前端架構(gòu)的必備技能。這篇文章主要介紹了淺談HTTP 緩存并用node實(shí)現(xiàn)緩存,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-10-10
  • Node.js中的進(jìn)程間通信

    Node.js中的進(jìn)程間通信

    這篇文章主要介紹了Node.js中的進(jìn)程間通信,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容戒殺,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-09-09
  • Node.js Continuation Passing Style( CPS與回調(diào))

    Node.js Continuation Passing Style( CPS與

    這篇文章主要介紹了Node.js Continuation Passing Style,將回調(diào)函數(shù)作為參數(shù)傳遞,這種書(shū)寫(xiě)方式通常被稱(chēng)為Continuation Passing Style(CPS),它的本質(zhì)仍然是一個(gè)高階函數(shù),CPS最初是各大語(yǔ)言中對(duì)排序算法的實(shí)現(xiàn)
    2022-06-06
  • node.js中koa和express的差異對(duì)比

    node.js中koa和express的差異對(duì)比

    Express和koa都是服務(wù)端的開(kāi)發(fā)框架,服務(wù)端開(kāi)發(fā)的重點(diǎn)是對(duì)HTTP Request和HTTP Response兩個(gè)對(duì)象的封裝和處理,下面這篇文章主要給大家介紹了關(guān)于node.js中koa和express的差異對(duì)比,需要的朋友可以參考下
    2023-05-05
  • nodeJs的安裝與npm全局環(huán)境變量的配置詳解

    nodeJs的安裝與npm全局環(huán)境變量的配置詳解

    這篇文章主要介紹了nodeJs的安裝與npm全局環(huán)境變量的配置詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • nodejs log4js 使用詳解

    nodejs log4js 使用詳解

    這篇文章主要介紹了nodejs log4js 使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Nodejs之http的表單提交

    Nodejs之http的表單提交

    這篇文章主要為大家詳細(xì)介紹了Nodejs之http的表單提交,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • nodejs使用Sequelize框架操作數(shù)據(jù)庫(kù)的實(shí)現(xiàn)

    nodejs使用Sequelize框架操作數(shù)據(jù)庫(kù)的實(shí)現(xiàn)

    這篇文章主要介紹了nodejs使用Sequelize框架操作數(shù)據(jù)庫(kù)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10

最新評(píng)論