这个需要对Excel表格的表头编码规则有所了解,目前示例代码只扩展到52个字段
/** *json数据导入导出Excel表格示例代码 * / var array_utils = require('./utils-array') var XLSX = require("xlsx"); module.exports = { writeExcel : function (headers,data,file,callback) { if(data.length ==0){ var obj = {} for(var v of headers){ obj[v] = '' } data.push(obj) } _writeExcel(headers,data,file,callback) }, /** * 获取excel原始信息 * @param path 文件路径 */ info : function(path){ return _info(path) }, /** * 格式化excel原始信息 * @param path 文件路径 */ formate_info : function (path) { return info_formate_info(path).formate }, info_formate_info : function (path) { return info_formate_info(path) } } var _info = function(path) { var k = XLSX.readFile(path, {type: 'base64'}); var result = {} k.SheetNames.forEach(function(sheetName) { var worksheet = k.Sheets[sheetName]; result[sheetName] = XLSX.utils.sheet_to_json(worksheet); }); return result } var info_formate_info = function(path){ var info = _info(path) var result = {} for(var value in info){ result[value] = {} } for(var key_info in info ){ var array = info[key_info] if(array_utils.isArray(array) || array.length>0){ var keys_array = Object.keys(array[0]) var obj = {} for(var value of keys_array){ obj[value] = [] } for( var key in obj ){ var subject_clone = JSON.parse(JSON.stringify(array)) subject_clone.filter( (v)=>{ for(var k in v){ if(k!=key){ delete v[k] } } return v; }) var subject_key_value = Array.from(array_utils.arrayQC(subject_clone),v => v[key] ) var obA = [] for(var v of subject_key_value){ var obk = { id : null, v : v } for(var ke in keys_array){ var thisIndex = keys_array.findIndex(x=>x==keys_array[ke]) var currentIndex = keys_array.findIndex(x=>x==key) if( thisIndex < currentIndex){ try { var thisObj = array.find(x=>x[ key ] == v ) obk[keys_array[ke]] = thisObj[ keys_array[ke] ] }catch (e){ console.error(e) } } } obA.push(obk) } obj[key] = obA } result[key_info]= obj } } return { info : info, formate : result } } var _writeExcel = function (headers,data,file,callback) { var _headers = headers var _data = data; var headers = _headers // 为 _headers 添加对应的单元格位置 .map((v, i) => Object.assign({}, { v: v, position:num(i)+1 })) // 转换成 worksheet 需要的结构 .reduce((prev, next) => Object.assign({}, prev, {[next.position]: {v: next.v}}), {}); var data = _data .map((v, i) => _headers.map((k, j) => Object.assign({}, { v: v[k], position:num(j) + (i+2) }))) // 对刚才的结果进行降维处理(二维数组变成一维数组) .reduce((prev, next) => prev.concat(next)) // 转换成 worksheet 需要的结构 .reduce((prev, next) => Object.assign({}, prev, {[next.position]: {v: next.v}}), {}); // 合并 headers 和 data // console.log("测试data",data) var output = Object.assign({}, headers, data); // 获取所有单元格的位置 var outputPos = Object.keys(output); // 计算出范围 var ref = outputPos[0] + ':' + outputPos[outputPos.length - 1]; // 构建 workbook 对象 var wb = { SheetNames: ['Sheet1'], Sheets: { 'Sheet1': Object.assign({}, output, { '!ref': ref }) } }; // 导出 Excel XLSX.writeFileAsync( file , wb,function (err) { callback(err) }); } //定位Excel位置 var num=function(i){ var n=parseInt(i+65) if(n>90){ n=String.fromCharCode(65)+String.fromCharCode(i+39) return n }else { n=String.fromCharCode(n) return n } }
以上这篇js导出Excel表格超出26位英文字符的解决方法ES6就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年11月28日
2024年11月28日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]