DDR爱好者之家 Design By 杰米
这个需要对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就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
2025年11月09日
2025年11月09日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]