xlsxExport.utils.js

一个导出excel文件的导出工具

目前為 2022-08-09 提交的版本,檢視 最新版本

此腳本不應該直接安裝,它是一個供其他腳本使用的函式庫。欲使用本函式庫,請在腳本 metadata 寫上: // @require https://update.cn-greasyfork.org/scripts/449211/1079584/xlsxExportutilsjs.js

  1. /*
  2. @author Parker
  3. @version 2020-05-08
  4. @aim 对xlsx-style方法进行二次封装 方便调用以导出带样式Excel
  5. @aim 对 XSU 进行封装和调用
  6. @usage XSExport.xxxx()
  7.  
  8. 依赖于
  9. 1. xlsx.core.min.js
  10. 2. xlsxStyle.core.min.js
  11. 3. xlsxStyle.utils.js
  12. */
  13. var XSExport = {};
  14.  
  15. /**
  16. * 通用的打开下载对话框方法,没有测试过具体兼容性
  17. * @param url 下载地址,也可以是一个blob对象,必选
  18. * @param saveName 保存文件名,可选
  19. */
  20. XSExport.openDownloadDialog = function(url, saveName){
  21. if(typeof url == 'object' && url instanceof Blob)
  22. {
  23. url = URL.createObjectURL(url); // 创建blob地址
  24. }
  25. var aLink = document.createElement('a');
  26. aLink.href = url;
  27. aLink.download = saveName || ''; // HTML5新增的属性,指定保存文件名,可以不要后缀,注意,file:///模式下不会生效
  28. var event;
  29. if(window.MouseEvent) event = new MouseEvent('click');
  30. else
  31. {
  32. event = document.createEvent('MouseEvents');
  33. event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
  34. }
  35. aLink.dispatchEvent(event);
  36. }
  37.  
  38. /**
  39. * 将一个sheet转成最终的excel文件的blob对象,然后利用URL.createObjectURL下载
  40. * @param sheet sheet数据
  41. * @param sheetName excel页内签
  42. */
  43. XSExport.sheet2blob = function(sheet, sheetName) {
  44. var that = this;
  45. sheetName = sheetName || 'sheet1';
  46. var workbook = {
  47. SheetNames: [sheetName],
  48. Sheets: {}
  49. };
  50. workbook.Sheets[sheetName] = sheet;
  51. // 生成excel的配置项
  52. var wopts = {
  53. bookType: 'xlsx', // 要生成的文件类型
  54. bookSST: false, // 是否生成Shared String Table,官方解释是,如果开启生成速度会下降,但在低版本IOS设备上有更好的兼容性
  55. type: 'binary'
  56. };
  57. // 设置样式
  58. that.setWorkbookStyle(workbook,workbook.SheetNames[0]);
  59. var wbout = xlsxStyle.write(workbook,wopts);
  60. var blob = new Blob([s2ab(wbout)], {type:"application/octet-stream"});
  61. // 字符串转ArrayBuffer
  62. function s2ab(s) {
  63. var buf = new ArrayBuffer(s.length);
  64. var view = new Uint8Array(buf);
  65. for (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
  66. return buf;
  67. }
  68. return blob;
  69. }
  70.  
  71. /**
  72. * 自定义对应表格样式
  73. * @param wb workbook Excel工作布
  74. * @param sheetName excel页内签名称
  75. */
  76. XSExport.setWorkbookStyle = function(wb,sheetName){
  77. var cols = XSU.getMaxCol(wb,sheetName);//当前最大列
  78. //wb样式处理,调用xlsxStyle.utils方法
  79.  
  80. //------------------通用表格样式----------------------------
  81. XSU.mergeCells(wb,sheetName,"A1",cols); //合并title单元格
  82. XSU.setFontTypeAll(wb,sheetName,'Arial');//字体:Arial
  83. XSU.setFontSizeAll(wb,sheetName,10);//字体大小:10
  84. XSU.setAlignmentHorizontalAll(wb,sheetName,'center');//垂直居中
  85. XSU.setAlignmentVerticalAll(wb,sheetName,'center');//水平居中
  86. XSU.setBorderDefaultAll(wb,sheetName);//设置所有单元格默认边框
  87. //-------------------------个性化----------------------------
  88. //列宽设置 1wch为1英文字符宽度 (统一放大一下宽度)
  89. XSU.setColWidthAll(wb,sheetName,15);
  90. //设置A 行 主标题 默认样式 必须最后设置 否则可能会被其他覆盖
  91. XSU.setTitleStylesDefault(wb,sheetName);
  92. //设置B 行 小标题 默认样式 必须最后设置 否则可能会被其他覆盖
  93. XSU.setSecondRowStylesDefault(wb,sheetName);
  94. }
  95.  
  96.  
  97. /**
  98. * 导出excel
  99. * @param data 原始数据
  100. * 数据格式为 第一行是 小标题 后续行则是对应行数据
  101. * 例:
  102. * data = [
  103. * ['姓名','年龄','性别'],
  104. * ['张三','12','男'],
  105. * ['李四','18','女']
  106. * ]
  107. * @param title 标题名称(用于excel内 第一行标题 和 导出文件名)
  108. */
  109. XSExport.excelExport = function(data,title){
  110. var that = this;
  111. var aoa = data;
  112. // 插入头部
  113. var header = [];
  114. header.push(title);
  115. var cols = aoa[0].length;
  116. for(var i=0;i<cols-1;i++){
  117. header.push("");
  118. }
  119. aoa.unshift(header);
  120. // 生成sheet
  121. var sheet = XLSX.utils.aoa_to_sheet(aoa);
  122. // 二进制文件
  123. var blob = that.sheet2blob(sheet);
  124. that.openDownloadDialog(blob, title+that.dateToStr('yyyyMMddHHmmss')+'.xlsx');
  125. }
  126. /**
  127. * 日期对象转换为指定格式的字符串
  128. * f 日期格式,格式定义如下 yyyy-MM-dd HH:mm:ss
  129. * date Date日期对象, 如果缺省,则为当前时间
  130. *
  131. * YYYY/yyyy/YY/yy 表示年份
  132. * MM/M 月份
  133. * W/w 星期
  134. * dd/DD/d/D 日期
  135. * hh/HH/h/H 时间
  136. * mm/m 分钟
  137. * ss/SS/s/S 秒
  138. * string 指定格式的时间字符串
  139. */
  140. XSExport.dateToStr = function(formatStr, date){
  141. formatStr = arguments[0] || "yyyy-MM-dd HH:mm:ss";
  142. date = arguments[1] || new Date();
  143. var str = formatStr;
  144. var Week = ['日','一','二','三','四','五','六'];
  145. str=str.replace(/yyyy|YYYY/,date.getFullYear());
  146. str=str.replace(/yy|YY/,(date.getYear() % 100)>9?(date.getYear() % 100).toString():'0' + (date.getYear() % 100));
  147. str=str.replace(/MM/,date.getMonth()>=9?(date.getMonth() + 1):'0' + (date.getMonth() + 1));
  148. str=str.replace(/M/g,date.getMonth());
  149. str=str.replace(/w|W/g,Week[date.getDay()]);
  150.  
  151. str=str.replace(/dd|DD/,date.getDate()>9?date.getDate().toString():'0' + date.getDate());
  152. str=str.replace(/d|D/g,date.getDate());
  153.  
  154. str=str.replace(/hh|HH/,date.getHours()>9?date.getHours().toString():'0' + date.getHours());
  155. str=str.replace(/h|H/g,date.getHours());
  156. str=str.replace(/mm/,date.getMinutes()>9?date.getMinutes().toString():'0' + date.getMinutes());
  157. str=str.replace(/m/g,date.getMinutes());
  158.  
  159. str=str.replace(/ss|SS/,date.getSeconds()>9?date.getSeconds().toString():'0' + date.getSeconds());
  160. str=str.replace(/s|S/g,date.getSeconds());
  161.  
  162. return str;
  163. }