7-8 WPS JS宏 对象使用实例5--按多字段做多种汇总

7-8 WPS JS宏 对象使用 实例5--按多字段做多种汇总

对象使用 实例5 按多字段做多种汇总

原数据和结果

代码:

function test(){

var arr=Sheets("销售表").Range("a2",Sheets("销售表").Range("e9999").End(xlUp)).Value();

var obj={},wsf=WorksheetFunction,newarr=[["仓库","年份","品名","求和","批次"]];

for(var ar of arr){

var txt=`${[ar[0],ar[1],ar[2]]}`;//学习重点:

if(txt in obj){//学习重点:新用法一次查3个值,必须3个值=true,

obj[txt].push(ar[4]);//第二次以上添加ar[4]

}else{

obj[txt]=[ar[4]];//第一次添加ar[4]

}

}

for(var [key,zhi] of Object.entries(obj)){

newarr.push([...key.split(","),wsf.Sum(zhi),wsf.CountA(zhi)]);//push()进行添加,用[]进行分行

}

Sheets("汇总表").Range("a1").Resize(newarr.length,5).Value2=newarr;

}

javascript 复制代码
function test(){
var arr=Sheets("销售表").Range("a2",Sheets("销售表").Range("e9999").End(xlUp)).Value();
var obj={},wsf=WorksheetFunction,newarr=[["仓库","年份","品名","求和","批次"]];
for(var ar of arr){
var txt=`${[ar[0],ar[1],ar[2]]}`;//学习重点:
	if(txt in obj){//学习重点:新用法一次查3个值,必须3个值=true,
	obj[txt].push(ar[4]);//第二次以上添加ar[4]
	}else{
	obj[txt]=[ar[4]];//第一次添加ar[4]
	}
	
		}
for(var [key,zhi] of Object.entries(obj)){

newarr.push([...key.split(","),wsf.Sum(zhi),wsf.CountA(zhi)]);//push()进行添加,用[]进行分行
}
Sheets("汇总表").Range("a1").Resize(newarr.length,5).Value2=newarr;
}
相关推荐
sheji34161 小时前
【开题答辩全过程】以 基于Spring Boot的旅游推荐系统的设计与实现为例,包含答辩的问题和答案
spring boot·后端·旅游
只是懒得想了2 小时前
Go语言ORM深度解析:GORM、XORM与entgo实战对比及最佳实践
开发语言·数据库·后端·golang
西门吹-禅2 小时前
react native --Expo---Android 开发
javascript·react native·react.js
谢尔登2 小时前
React19 渲染流程
前端·javascript·架构·ecmascript
我是伪码农2 小时前
Vue 1.29
前端·javascript·vue.js
爱吃山竹的大肚肚2 小时前
异步导出方案
java·spring boot·后端·spring·中间件
css趣多多2 小时前
Vue动态组件以及keep-alive的使用
前端·javascript·vue.js
摘星编程2 小时前
React Native + OpenHarmony:自定义useLanguage语言切换
javascript·react native·react.js
三水不滴2 小时前
从原理、场景、解决方案深度分析Redis分布式Session
数据库·经验分享·redis·笔记·分布式·后端·性能优化
Hx_Ma162 小时前
SpringMVC框架(上)
java·后端