7-16 WPS JS宏 RandBetween、Address实例8--[唯一性]类的应用

7-16 WPS JS宏 RandBetween Address实例8--[唯一性]类的应用

  • 函数

RandBetween

为excel函数,需要WorksheetFunction调用。

格式:WorksheetFunction.RandBetween(起点,终点)

Address

为显示地址

格式:区域范围等.Address()

二、 自定义类 测试

数据与结果1:

结果2:

生成新工作薄,写入不重复的名字

代码:

class zidinyihanshu{

//初始化设置,只要被激活先运行初始化内容,保存结果。

constructor(Rngs1){//初始化设置函数constructor

this.Rngs=Rngs1;//重点:调用Rngs1可直接使用,调用Rngs需要用this.Rngs

this.arr=Rngs1.Value().flat();//表达式返回属性值

this.list=[...new Set(Rngs1.Value().flat())];//打平数组,集合清理重复值再用[]变为数组

}

//需要时在调用

Sum1(){return this.arr.reduce((x,y)=>x+y)};//有返回值(函数)

Rngcolor(color){this.Rngs.Interior.Colorlndex=color}; //无返回值(函数)

color1(){

for (var v of this.list){

var num=WorksheetFunction.RandBetween(1,999999);

for (var a of this.Rngs){

if (a.Value()==v){a.Interior.Color=num}

}}}

}

//要求:着色各工作表的相同的姓名,并提取每表唯一值

function 重复值单元格上色(){

var arr=[];

for (var ws of Sheets){

var rns=ws.Range("a1",ws.Cells(999,"a").End(xlUp));

var disoj=new zidinyihanshu(rns);

disoj.color1();

arr.push(disoj.list)

}

Console.log(JSON.stringify(arr));

Console.log(rns.Address());//本节学习内容:Address()为显示地址

Workbooks.Add();

var lie=arr.reduce((x,y)=>(x.length>y.length)?x:y).length;

Range("a1").Resize(arr.length,lie).Value2=arr;

}

javascript 复制代码
////自定义类
class zidinyihanshu{
	//初始化设置,只要被激活先运行初始化内容,保存结果。
	constructor(Rngs1){//初始化设置函数constructor
		this.Rngs=Rngs1;//重点:调用Rngs1可直接使用,调用Rngs需要用this.Rngs
		this.arr=Rngs1.Value().flat();//表达式返回属性值
		this.list=[...new Set(Rngs1.Value().flat())];//打平数组,集合清理重复值再用[]变为数组
		}
	//需要时在调用
	Sum1(){return this.arr.reduce((x,y)=>x+y)};//有返回值(函数)
	Rngcolor(color){this.Rngs.Interior.Colorlndex=color}; //无返回值(函数)
	
	color1(){
		for (var v of this.list){
		var num=WorksheetFunction.RandBetween(1,999999);
		for (var a of this.Rngs){
		if (a.Value()==v){a.Interior.Color=num}
		}}}
	}


//要求:着色各工作表的相同的姓名,并提取每表唯一值
function 重复值单元格上色(){
var arr=[];
for (var ws of Sheets){
var rns=ws.Range("a1",ws.Cells(999,"a").End(xlUp));
var disoj=new zidinyihanshu(rns);
disoj.color1();
arr.push(disoj.list)
}
Console.log(JSON.stringify(arr));
Console.log(rns.Address());//本节学习内容:Address()为显示地址

Workbooks.Add();

var lie=arr.reduce((x,y)=>(x.length>y.length)?x:y).length;
Range("a1").Resize(arr.length,lie).Value2=arr;
}
相关推荐
还在忙碌的吴小二15 小时前
Harness 最佳实践:Java Spring Boot 项目落地 OpenSpec + Claude Code
java·开发语言·spring boot·后端·spring
liliangcsdn15 小时前
mstsc不在“C:\Windows\System32“下在C:\windows\WinSxS\anmd64xxx“问题分析
开发语言·windows
小陈工16 小时前
2026年4月7日技术资讯洞察:下一代数据库融合、AI基础设施竞赛与异步编程实战
开发语言·前端·数据库·人工智能·python
KAU的云实验台16 小时前
【算法精解】AIR期刊算法IAGWO:引入速度概念与逆多元二次权重,可应对高维/工程问题(附Matlab源码)
开发语言·算法·matlab
Cobyte16 小时前
3.响应式系统基础:从发布订阅模式的角度理解 Vue2 的数据响应式原理
前端·javascript·vue.js
会编程的土豆16 小时前
【数据结构与算法】再次全面了解LCS底层
开发语言·数据结构·c++·算法
竹林81816 小时前
从零到一:在React前端中集成The Graph查询Uniswap V3池数据实战
前端·javascript
jerryinwuhan16 小时前
RDD第二次练习
开发语言·c#
wechat_Neal16 小时前
Golang的车载应用场景
开发语言·后端·golang