摘要:使用中庫(kù)進(jìn)行的生成操作近日,應(yīng)領(lǐng)導(dǎo)要求,從網(wǎng)上抓了一大批數(shù)據(jù)存入了數(shù)據(jù)庫(kù),可是媽媽批,市場(chǎng)妹子要的是表格啊,畢竟妹子的話還是要聽(tīng)的關(guān)鍵人家語(yǔ)氣蠻好的,就從網(wǎng)上查一些資料。
## 使用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)注釋,有些人的代碼你確定你自己跑過(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"]//這是第一行 俗稱列名 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)單的解釋,這個(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)論哦 ,作者真正意義的第一篇博客。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/106830.html
摘要:支持讀寫(xiě)的模塊基于解析文件數(shù)據(jù)及生成文件,僅支持格式文件基于解析文件數(shù)據(jù),支持及格式文件基于將數(shù)據(jù)生成導(dǎo)出文件,生成文件格式為基于從文件中提取數(shù)據(jù),僅支持格式文件。代碼如下讀取文件內(nèi)容將文件內(nèi)容插入新的文件中 支持讀寫(xiě)Excel的node.js模塊node-xlsx: 基于Node.js解析excel文件數(shù)據(jù)及生成excel文件,僅支持xlsx格式文件;excel-parser: 基于...
摘要:起因運(yùn)營(yíng)人員需要將后臺(tái)的表格導(dǎo)出成,由于后端的同學(xué)忙于其他事情,想著是不是可以自己做一個(gè)服務(wù)來(lái)生成。另外再搭配就可以提供一個(gè)允許跨域請(qǐng)求的服務(wù)。這樣一個(gè)簡(jiǎn)單的接口就寫(xiě)完了,只要調(diào)用傳入和就可以生成文檔。 起因 運(yùn)營(yíng)人員需要將后臺(tái)的表格導(dǎo)出成Excel,由于后端的同學(xué)忙于其他事情,想著是不是可以自己做一個(gè)服務(wù)來(lái)生成。了解到有node-xlsx這樣的工具以后就開(kāi)工了。 框架 后臺(tái)選用了ko...
摘要:之后需要對(duì)中的結(jié)果數(shù)據(jù)做分析,并且制作圖表寫(xiě)周報(bào)發(fā)給老大。輪到我值班的時(shí)候就用寫(xiě)了一個(gè)腳本自動(dòng)處理中的數(shù)據(jù),并且將數(shù)據(jù)再寫(xiě)入文件。腳本目的讀取文件,分析中的數(shù)據(jù),并且將結(jié)果寫(xiě)入中。 背景 因?yàn)?Team 本身工作性質(zhì)的問(wèn)題,平時(shí)需要值班。值班數(shù)據(jù)可以導(dǎo)出為本地的Excel文件。之后需要對(duì)Excel中的結(jié)果數(shù)據(jù)做分析,并且制作圖表寫(xiě)周報(bào)發(fā)給老大。 對(duì)于我這種對(duì)word都玩不轉(zhuǎn)的人,別說(shuō)用...
摘要:或者可以更加傻瓜一點(diǎn),把過(guò)程寫(xiě)到一個(gè)回調(diào)函數(shù)中的請(qǐng)求或者原生的的方法,這樣產(chǎn)品訪問(wèn)某一個(gè)就可以自動(dòng)生成頁(yè)面了。又或者終極一點(diǎn),把上線過(guò)程也寫(xiě)到回調(diào)函數(shù)中,這樣便實(shí)現(xiàn)了從到線上頁(yè)面的全部自動(dòng)化,整個(gè)過(guò)程對(duì)產(chǎn)品人員完全不可見(jiàn)。 專題頁(yè)面通常是一些為了當(dāng)時(shí)的活動(dòng)而做的一些短期的頁(yè)面,有的專題,僅僅是一些說(shuō)明信息,沒(méi)有過(guò)多的鏈接,此時(shí)直接切大圖就可以完成。而有一些專題是為了推廣自家或者其他方的...
摘要:寫(xiě)入新的文件完成合并完整代碼文件夾路徑把要合并的文件放在文件夾內(nèi)提交成績(jī)開(kāi)始合并表格內(nèi)部字段不一致,請(qǐng)檢查后再合并。 簡(jiǎn)述需求 我們?cè)谟肊xcel表格的時(shí)候經(jīng)常需要合并數(shù)據(jù),比如統(tǒng)計(jì)整個(gè)年級(jí)的數(shù)據(jù)的時(shí)候,需要合并每個(gè)班成績(jī)的時(shí)候,這就需要一個(gè)快速將很多張數(shù)據(jù)類型相同表合并的組件 showImg(https://segmentfault.com/img/remote/1460000019...
閱讀 1791·2021-11-11 11:02
閱讀 1697·2021-09-22 15:55
閱讀 2498·2021-09-22 15:18
閱讀 3499·2019-08-29 11:26
閱讀 3757·2019-08-26 13:43
閱讀 2656·2019-08-26 13:32
閱讀 912·2019-08-26 10:55
閱讀 973·2019-08-26 10:27