222
schangxiang@126.com
2024-12-09 f2f4ecd04b2987f6aed8216442e82a81009c2366
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
//导出指定列的excel数据
import { ElMessage } from 'element-plus';
// import XLSX from 'xlsx';
import XLSXS from 'xlsx-js-style';
 
export function exportExcel(dataSource: any[], entozh: any={}, type = "xlsx", name = "全部信息") {
  const nowdata = dataSource;
  if (nowdata != undefined) {
  //   let i = 1;
  //   const json = nowdata.map((item: { [x: string]: any; }) => {
  //     return Object.keys(item).reduce((newData, key) => {
  //       const newKey = entozh[key] //|| key
  //       if (newKey !== undefined) {
  //         if (key !== 'key') {
  //           //不需要key
  //           if (key === 'id') {
  //             newData[newKey] = i;
  //             i++;
  //           } else {
  //             newData[newKey] = item[key]
  //           }
  //         }
  //       }
  //       return newData
  //     }, {})
  //   });
  //   // debugger;
  //   console.log(json,'1111')
  //   const sheet = XLSXS.utils.json_to_sheet(json);
  //   openDownloadDialog(sheet2blob(sheet, undefined, type), `${name}.${type}`);
    const keysArr: string[] = Object.keys(entozh)
    const aoa = [];
    
    const headerArr: any[] = [];
    keysArr.forEach(item => {
      if(item != 'id') {
        headerArr.push(entozh[item])
      }
    })
    const contentArr: any[][] = [];
    nowdata.forEach(item => {
      const arr: any[] = [];
      keysArr.forEach(key => {
        if(key != 'id') {
          arr.push(item[key])
        }
      })
      contentArr.push(arr)
    })
    aoa.push(headerArr,...contentArr)
    // console.log(aoa)
    const worksheet = XLSXS.utils.aoa_to_sheet(aoa)
    openDownloadDialog(sheet2blob(worksheet, undefined, type), `${name}.${type}`);
    // XLSXS.utils.book_append_sheet(workbook,worksheet,`${name}.${type}`)
    
  } else {
    ElMessage.warning('无数据')
  }
 
}
 
export function openDownloadDialog(url: string | any, saveName: string) {
  if (typeof url == 'object' && url instanceof Blob) {
    url = URL.createObjectURL(url); // 创建blob地址
  }
  const aLink = document.createElement('a');
  aLink.href = url;
  aLink.download = saveName || ''; // HTML5新增的属性,指定保存文件名,可以不要后缀,注意,file:///模式下不会生效
  let event;
  if (window.MouseEvent) event = new MouseEvent('click');
  else {
    event = document.createEvent('MouseEvents');
    event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
  }
  aLink.dispatchEvent(event);
}
 
export function sheet2blob(sheet: XLSXS.WorkSheet, sheetName: string | undefined, type = "xlsx") {
  sheetName = sheetName || 'sheet1';
  const workbook = {
    SheetNames: [sheetName],
    Sheets: {}
  };
  workbook.Sheets[sheetName] = sheet; // 生成excel的配置项
 
  const wopts: any = {
    bookType: `${type}`, // 要生成的文件类型
    bookSST: false, // 是否生成Shared String Table,官方解释是,如果开启生成速度会下降,但在低版本IOS设备上有更好的兼容性
    type: 'binary'
  };
 
  const wbout = XLSXS.write(workbook, wopts);
  const blob = new Blob([s2ab(wbout)], {
    type: "application/octet-stream"
  }); // 字符串转ArrayBuffer
  function s2ab(s: string) {
    const buf = new ArrayBuffer(s.length);
    const view = new Uint8Array(buf);
    for (let i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
    return buf;
  }
 
  return blob;
}