摘要:使用中庫進行的生成操作近日,應領導要求,從網上抓了一大批數據存入了數據庫,可是媽媽批,市場妹子要的是表格啊,畢竟妹子的話還是要聽的關鍵人家語氣蠻好的,就從網上查一些資料。
## 使用nodejs中node-xlsx庫進行excel的生成操作 ##
近日,應領導要求,從網上抓了一大批數據存入了數據庫,可是媽媽批 ,市場妹子要的是excel表格啊,畢竟妹子的話還是要聽的(關鍵人家語氣蠻好的),就從網上查一些資料。可是查來查去發現很多都是復制粘貼,說實話真的討厭這樣行為,代碼好歹你自己先跑跑,加點注釋,有些人的代碼你確定你自己跑過? 就發到網上坑人,各種耽誤別人的時間。
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.下面上關鍵代碼;
數據填充 sqlite.queryData("select * from personInfo",(rows)=>{ //rows是個從數據庫里面讀出來的數組,大家就把他當成一個普通的數組就ok let data = [] // 其實最后就是把這個數組寫入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中添加的要是數組,可以將對象的值分解添加進數組,例如:["1","name","上海"] }); this.writeXls(data) }) 先說一下title 這個數組就是excel中的第一行數據,就是列名,用來描述的。算了,我還是上圖解釋吧 ![就是表頭]
表頭完了,下面插入數據,
簡單的解釋,這個data是個二維數組,它里面的每個數組代表著一行的數據,所以大家添加的時候一定要對應上。添加的每個數組長度要 相同(data中一定要添加數組啊,切記) 你添加了幾個數組,在生成的excel中內容就會有多少行的數據,假如我上面的rows數組長度是3那么我生成的excel中內容的數據就是三 行(說到這里大家明白了嗎,表述不行,急死我了)。 當我們把data填充數據填充完畢后,就開始下一步,進行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是個后臺系統,他是有權限修改文件的,不像瀏覽器,瀏覽器是無權默認修改文件的,你想想你正在打開瀏覽器,它就把你的電腦里的內容都修改沒了,或者偷偷上傳這是多么可怕的事情,所以瀏覽器的功能還是被限制了很多很多的,以前做安卓生成這些也是麻煩的很,現在真的該感謝一下nodejs用的很爽。喜歡的話,請點贊評論哦 ,作者真正意義的第一篇博客。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/106830.html
摘要:支持讀寫的模塊基于解析文件數據及生成文件,僅支持格式文件基于解析文件數據,支持及格式文件基于將數據生成導出文件,生成文件格式為基于從文件中提取數據,僅支持格式文件。代碼如下讀取文件內容將文件內容插入新的文件中 支持讀寫Excel的node.js模塊node-xlsx: 基于Node.js解析excel文件數據及生成excel文件,僅支持xlsx格式文件;excel-parser: 基于...
摘要:起因運營人員需要將后臺的表格導出成,由于后端的同學忙于其他事情,想著是不是可以自己做一個服務來生成。另外再搭配就可以提供一個允許跨域請求的服務。這樣一個簡單的接口就寫完了,只要調用傳入和就可以生成文檔。 起因 運營人員需要將后臺的表格導出成Excel,由于后端的同學忙于其他事情,想著是不是可以自己做一個服務來生成。了解到有node-xlsx這樣的工具以后就開工了。 框架 后臺選用了ko...
摘要:之后需要對中的結果數據做分析,并且制作圖表寫周報發給老大。輪到我值班的時候就用寫了一個腳本自動處理中的數據,并且將數據再寫入文件。腳本目的讀取文件,分析中的數據,并且將結果寫入中。 背景 因為 Team 本身工作性質的問題,平時需要值班。值班數據可以導出為本地的Excel文件。之后需要對Excel中的結果數據做分析,并且制作圖表寫周報發給老大。 對于我這種對word都玩不轉的人,別說用...
摘要:或者可以更加傻瓜一點,把過程寫到一個回調函數中的請求或者原生的的方法,這樣產品訪問某一個就可以自動生成頁面了。又或者終極一點,把上線過程也寫到回調函數中,這樣便實現了從到線上頁面的全部自動化,整個過程對產品人員完全不可見。 專題頁面通常是一些為了當時的活動而做的一些短期的頁面,有的專題,僅僅是一些說明信息,沒有過多的鏈接,此時直接切大圖就可以完成。而有一些專題是為了推廣自家或者其他方的...
摘要:寫入新的文件完成合并完整代碼文件夾路徑把要合并的文件放在文件夾內提交成績開始合并表格內部字段不一致,請檢查后再合并。 簡述需求 我們在用Excel表格的時候經常需要合并數據,比如統計整個年級的數據的時候,需要合并每個班成績的時候,這就需要一個快速將很多張數據類型相同表合并的組件 showImg(https://segmentfault.com/img/remote/1460000019...
閱讀 1776·2021-11-11 11:02
閱讀 1679·2021-09-22 15:55
閱讀 2482·2021-09-22 15:18
閱讀 3488·2019-08-29 11:26
閱讀 3742·2019-08-26 13:43
閱讀 2646·2019-08-26 13:32
閱讀 897·2019-08-26 10:55
閱讀 965·2019-08-26 10:27