您好,登錄后才能下訂單哦!
怎么在nodejs中利用node-xlsx生成一個excel文件?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
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中利用node-xlsx生成一個excel文件的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。