Node.js服務使用exceljs生成excel,實現(xiàn)導出

最近在使用node.js + exceljs做導出功能, 總結(jié)一下其基本使用方法:

依賴庫引入
const fs = require('fs')
const Excel = require('exceljs')
初始化Excel
const workbook = new Excel.Workbook()
workbook.creator = 'test'
workbook.lastModifiedBy = 'test'
workbook.created = new Date()
workbook.modified = new Date()
生成一個工作表
let sheet = workbook.addWorksheet('2018-10報表')

# Add column headers and define column keys and widths
sheet.columns = [
  {header: '創(chuàng)建日期', key: 'create_time', width: 15},
  {header: '單號', key: 'id', width: 15},
  {header: '電話號碼', key: 'phone', width: 15},
  {header: '地址', key: 'address', width: 15}
]
const data = [{
  create_time: '2018-10-01',
  id: '787818992109210',
  phone: '11111111111',
  address: '深圳市'
}]
# Add an array of rows
sheet.addRows(data)
生成excel文件
const filePath = `server/attachement/用戶報表.xlsx`
return await workbook.xlsx.writeFile(filePath).then( async () => {
  this.ctx.attachment(`用戶報表.xlsx`)
  this.ctx.type = '.xlsx'
  this.ctx.body = fs.readFileSync(filePath)
}, function (err: any) {
  console.log(err)
})

在一些復雜的情況下接校,我們可能需要生成多級表頭狮崩,如下圖:


屏幕快照 2018-11-29 上午11.37.08.png
// 添加表頭
sheet.getRow(1).values = ['種類', '銷量',,,, '店鋪']
sheet.getRow(2).values = ['種類', '2018-05', '2018-06', '2018-07', '2018-08', '店鋪']

// 添加數(shù)據(jù)項定義,與之前不同的是睦柴,此時去除header字段
sheet.columns = [
  {key: 'category', width: 30},
  {key: '2018-05', width: 30},
  {key: '2018-06', width: 30},
  {key: '2018-07', width: 30},
  {key: '2018-08', width: 30},
  {key: 'store', width: 30},
]
  const data = [{
  category: '衣服',
  '2018-05': 300,
  '2018-06': 230,
  '2018-07': 730,
  '2018-08': 630,
  'store': '王小二旗艦店'
}, {
  category: '零食',
  '2018-05': 672,
  '2018-06': 826,
  '2018-07': 302,
  '2018-08': 389,
  'store': '吃吃貨'
}]
  sheet.addRows(data)

// 合并單元格
  sheet.mergeCells(`B1:E1`)
  sheet.mergeCells('A1:A2')
  sheet.mergeCells('F1:F2')

// 設置每一列樣式
  const row = sheet.getRow(1)
  row.eachCell((cell, rowNumber) => {
    sheet.getColumn(rowNumber).alignment = {vertical: 'middle', horizontal: 'center'}
    sheet.getColumn(rowNumber).font = {size: 14, family: 2}
  })
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末坦敌,一起剝皮案震驚了整個濱河市侣诵,隨后出現(xiàn)的幾起案子狱窘,更是在濱河造成了極大的恐慌,老刑警劉巖蘸炸,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異幻馁,居然都是意外死亡越锈,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進店門甘凭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人丹弱,你說我怎么就攤上這事《愀欤” “怎么了?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵隆檀,是天一觀的道長。 經(jīng)常有香客問我恐仑,道長泉坐,這世上最難降的妖魔是什么裳仆? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮歧斟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘构捡。我一直安慰自己,他們只是感情好勾徽,可當我...
    茶點故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著畅姊,像睡著了一般。 火紅的嫁衣襯著肌膚如雪若未。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天粗合,我揣著相機與錄音乌昔,去河邊找鬼隙疚。 笑死磕道,一個胖子當著我的面吹牛供屉,可吹牛的內(nèi)容都是我干的溺蕉。 我是一名探鬼主播,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼疯特,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了漓雅?” 一聲冷哼從身側(cè)響起羹与,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤庶灿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后往踢,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡峻呕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了猪贪。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,703評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡热押,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出桶癣,到底是詐尸還是另有隱情,我是刑警寧澤牙寞,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布莫秆,位于F島的核電站间雀,受9級特大地震影響镊屎,放射性物質(zhì)發(fā)生泄漏惹挟。R本人自食惡果不足惜杯道,卻給世界環(huán)境...
    茶點故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一责蝠、第九天 我趴在偏房一處隱蔽的房頂上張望党巾。 院中可真熱鬧霜医,春花似錦、人聲如沸肴敛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽捻勉。三九已至,卻和暖如春刀森,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背研底。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留冠蒋,地道東北人。 一個月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓抖剿,卻偏偏與公主長得像,于是被迫代替她去往敵國和親牙躺。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,601評論 2 353

推薦閱讀更多精彩內(nèi)容