angular 将数据导出excel表格

下载

npm install @types/exceljs @types/file-saver  file-saver -S

疑问为什么下载了 @types/file-saver ,还下载后面的

因为会报错,不信自己试试,后面发现再下载file-saver 能解决问题

上代码

import {Component, OnInit} from '@angular/core';
import {Workbook} from 'exceljs';
import { saveAs } from 'file-saver';
@Component({
  selector: 'app-count-down',
  templateUrl: './count-down.component.html',
  styleUrls: ['./count-down.component.scss']
})
export class CountDownComponent implements OnInit {
  // 创建一个名字和年龄的数据
  json_data = [{
    "name": "Raja",
    "age": 20
  },
    {
      "name": "Mano",
      "age": 40
    },
    {
      "name": "Tom",
      "age": 40
    },
    {
      "name": "Devi",
      "age": 40
    },
    {
      "name": "Mango",
      "age": 40
    }
  ]

  constructor() {
  }

  ngOnInit(): void {
  }
	// 节点按钮直接下载
  downloadExcel() {
    // 创建工作薄
    let workbook = new Workbook();
    // 将名字添加到工作薄中
    let worksheet = workbook.addWorksheet('名字年龄表格')
    // 添加行的标题
    let header = ['名字', '年龄']
    worksheet.addRow(header);
    // 把数据按照一行一行添加到里面去
    for (let item of this.json_data) {
      worksheet.addRow(Object.values(item))
    }
    // 下载文件名
    let fname = '个人资料统计表';
    workbook.xlsx.writeBuffer().then(data => {
      let blob=new Blob([data],{ type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' });
      saveAs(blob, fname+'-'+new Date().valueOf()+'.xlsx');
    })
  }
}

posted @   猫神甜辣酱  阅读(863)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
历史上的今天:
2018-12-01 学习go语言一篇就够了(持续更新)
点击右上角即可分享
微信分享提示