6-13 WPS JS宏 Map实例2--拆分记录到表格

实例2--拆分记录到表格

原数据

结果:

代码:

function test(){

var pah = ThisWorkbook.Path + "//";

var arr = Range("A2", Range("E999").End(xlUp)).Value();

var titarr = ["编号", "姓名", "部门", "籍贯", "基本工资"];

var m = new Map();

for (var ar of arr) {

if (m.has(ar[2])) {

var newarr = m.get(ar[2]).concat([ar]);//concat为合并数组;如: var newarr = m.get(财政局).concat([["GH00005","孙明","财政局",38,5695]])

Console.log(JSON.stringify("1."+newarr));

//因newarr是数组不是映射所以打印不显示索引

//打印第一次运行结果:"1.编号,姓名,部门,籍贯,基本工资,GH00001,李五,财政局,18,5651,GH00005,孙明,财政局,38,5695"

m.set(ar[2], newarr);//m.set(财政局, [["编号","姓名","部门","籍贯","基本工资"],[GH00001,李五,财政局,18,5651],["GH00005","孙明","财政局",38,5695]);

Console.log(JSON.stringify("2."+[...m.entries()]));

//打印第一次运行结果:"2.财政局,编号,姓名,部门,籍贯,基本工资,GH00001,李五,财政局,18,5651,GH00005,孙明,财政局,38,5695,民政局,编号,姓名,部门,籍贯,基本工资,GH00002,王六,民政局,23,5662,卫健局,编号,姓名,部门,籍贯,基本工资,GH00003,王九,卫健局,28,5673,残联,编号,姓名,部门,籍贯,基本工资,GH00004,孙小一,残联,33,5684"

} else {

// 如果不存在,则先在 Map 中创建该部门分组,并将表头作为首行,后跟当前记录

m.set(ar[2], [titarr, ar]);// 如:m.set(财政局, [["编号","姓名","部门","籍贯","基本工资"],[GH00001,李五,财政局,18,5651]])

Console.log(JSON.stringify("3."+[...m.entries()]));

//监视窗口:m=[1];Map/object

//打印第一次运行结果:"3.财政局,编号,姓名,部门,籍贯,基本工资,GH00001,李五,财政局,18,5651"

}

}

// 创建一个新的工作簿

var wb = Workbooks.Add();

for (var [key, val] of m.entries()){ // 对 Map 进行遍历

var ws = wb.Sheets.Add(); // 每次创建一个新的工作表

ws.Name = key;//当前部门名称 key

ws.Range("A1").Resize(val.length, 5).Value2 = val;

}

// 删除新工作簿默认多余的最后一个空工作表

wb.Sheets(wb.Sheets.Count).Delete();

// 保存新工作簿到指定路径,文件名为 "拆分结果.xlsx",保存后关闭工作簿

wb.SaveAs(`${pah}拆分结果.xlsm`);

wb.Close();

}

javascript 复制代码
function test(){

    var pah = ThisWorkbook.Path + "//";

    var arr = Range("A2", Range("E999").End(xlUp)).Value();

    var titarr = ["编号", "姓名", "部门", "籍贯", "基本工资"];

    var m = new Map();

    for (var ar of arr) {
  
        if (m.has(ar[2])) {
            var newarr = m.get(ar[2]).concat([ar]);//concat为合并数组;如: var newarr = m.get(财政局).concat([["GH00005","孙明","财政局",38,5695]])
            Console.log(JSON.stringify("1."+newarr));
//因newarr是数组不是映射所以打印不显示索引   
//打印第一次运行结果:"1.编号,姓名,部门,籍贯,基本工资,GH00001,李五,财政局,18,5651,GH00005,孙明,财政局,38,5695"

            m.set(ar[2], newarr);//m.set(财政局, [["编号","姓名","部门","籍贯","基本工资"],[GH00001,李五,财政局,18,5651],["GH00005","孙明","财政局",38,5695]);
            Console.log(JSON.stringify("2."+[...m.entries()]));
//打印第一次运行结果:"2.财政局,编号,姓名,部门,籍贯,基本工资,GH00001,李五,财政局,18,5651,GH00005,孙明,财政局,38,5695,民政局,编号,姓名,部门,籍贯,基本工资,GH00002,王六,民政局,23,5662,卫健局,编号,姓名,部门,籍贯,基本工资,GH00003,王九,卫健局,28,5673,残联,编号,姓名,部门,籍贯,基本工资,GH00004,孙小一,残联,33,5684"
       
        } else {
            // 如果不存在,则先在 Map 中创建该部门分组,并将表头作为首行,后跟当前记录
            m.set(ar[2], [titarr, ar]);// 如:m.set(财政局, [["编号","姓名","部门","籍贯","基本工资"],[GH00001,李五,财政局,18,5651]])
             Console.log(JSON.stringify("3."+[...m.entries()]));
//监视窗口:m=[1];Map/object             
//打印第一次运行结果:"3.财政局,编号,姓名,部门,籍贯,基本工资,GH00001,李五,财政局,18,5651"

        }
    }
    
    // 创建一个新的工作簿
    var wb = Workbooks.Add();
    
    for (var [key, val] of m.entries()){ // 对 Map 进行遍历
      
        var ws = wb.Sheets.Add();  // 每次创建一个新的工作表
        ws.Name = key;//当前部门名称 key

        ws.Range("A1").Resize(val.length, 5).Value2 = val;
    }
    
    // 删除新工作簿默认多余的最后一个空工作表
    wb.Sheets(wb.Sheets.Count).Delete();
    
    // 保存新工作簿到指定路径,文件名为 "拆分结果.xlsx",保存后关闭工作簿
    wb.SaveAs(`${pah}拆分结果.xlsm`);
    wb.Close();
}
相关推荐
matlab_xiaowang2 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
前端摸鱼匠4 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker4 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
Linsk6 小时前
Java和JavaScript的关系真是雷峰和雷峰塔的关系吗?
java·javascript·oracle
当时只道寻常6 小时前
浏览器文本复制到剪贴板:企业级最佳实践
javascript
Alice-YUE7 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀8 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
莎士比亚的文学花园8 小时前
Linux驱动开发(3)——设备树
开发语言·javascript·ecmascript
01漫游者9 小时前
JavaScript函数与对象增强知识
开发语言·javascript·ecmascript
xiaoliuliu1234510 小时前
WPS 2025 安装教程:自定义路径+办公套件(64位)
wps