wps js宏编辑器案例2-单元格读写-随机选人

news/2024/11/29 2:49:39/

本案例讲述某企业的一个真实案例,该企业每周二早上有安全宣贯会议,差不多10来分钟左右,每次安全会上人事部门都会点名,那么问题来了,点名的名单哪儿来?为此,编写了一个简单js宏应用,产生随机名单,名单数量可设置,主要涉及js宏单元格的读写,具体如下。

1、案例演示

【表单1】人员清单
在这里插入图片描述
其中选中人数:xx人可设置,比如设置10,则执行运行后,只随机选取10人
点击“开始选人”按钮,会先清空表单2中已选中人员,然后重新填充新一轮的选中人员。

【表单2】选中人员
在这里插入图片描述
这是选中人数设置5人,的执行效果,随机从人员清单中选中了5人,以及生成时间。

2、代码说明

function CommandButton1_Click()
{let sheet1 = Worksheets.Item("人员清单");let sheet2 = Worksheets.Item("选中人员");let iPeople = sheet1.Range("B1").Value2;if (! iPeople) {MsgBox('选中人数不能为空, 请先设置');return;}if(MsgBox("确定开始选人吗?", jsOKCancel + jsQuestion) == 1) {let b4 = sheet1.Range("B4"), b4End = sheet1.Range("B4").End(xlDown);let iStart = 4, iEnd = b4End.Row;							// 最后一行行号sheet2.Range("A3:C22").Value2 = ""							// 清空选中人员sheet2.Range("B1").Value2 = new Date().toLocaleString();	// 填写生成时间sheet1.Range("D4:D" + iEnd).Value2 = 0;let iCount = 2;while(true) {let iRow = Math.floor(Math.random() * 1000000 % (iEnd + 10));if (iRow >= iStart && iRow <= iEnd && (! sheet1.Cells.Item(iRow, 4).Value2)) {iCount++;sheet1.Cells.Item(iRow, 4).Value2 = 1;sheet2.Cells.Item(iCount, 1).Value2 = sheet1.Cells.Item(iRow, 1).Value2;sheet2.Cells.Item(iCount, 2).Value2 = sheet1.Cells.Item(iRow, 2).Value2;sheet2.Cells.Item(iCount, 3).Value2 = sheet1.Cells.Item(iRow, 3).Value2;if (iCount >= iPeople + 2) break;}}}
}

1)实现原理

利用随机数、取模,产生一个随机行号:

  • 判断是否在人员清单的行号范围之内,如果是则判断该行是否已经被选中,如果是则产生新的随机行号继续判断,否则设置改行选中次数为1、填写人员信息到选中人员表单;
  • 判断选中人数是否已经达到设置人数,如果是则结束程序,否则继续产生人员;

2)代码说明

  • WorkSheet工作表获取,Worksheets.Item(“人员清单”)
  • 单元格读取
    • Range.Value2读取,sheet1.Range(“B1”).Value2,或Value()函数读取
    • Cells读取, sheet1.Cells.Item(iRow, 1).Value2
  • Range.End使用,b4End = sheet1.Range(“B4”).End(xlDown),获取B列最后一个有效行
  • MsgBox使用,提示框,具体参考:wps宏编辑器API关于msgbox和inputbox的使用说明

3)代码获取

可以到 https://gitee.com/zongtong2046/jsexcel/tree/master/ 获取,请下载:案例2_单元格读写_随机选人.xlsm

3、改进之处

由于安全早会是一个长周期会议,这周点名了,下周最好点之前没点名的人员,只要程序做个小变动即可实现。
在这里插入图片描述

  • 加个设置,选中次数超过几次,不再选中
  • 每次选人时,选中次数不再归零
  • 第一次执行时,选中次数设置1次后不再选中,则随机选取5个人,这5个人选中次数都为1;
  • 第二次执行时,选中次数设置1次后不再选中,此时原本选中的5个人,不能再被选中,只能选取其他人员;
  • 当所有人员基本被选中一遍后,下次在选人时,设置选中次数为2即可

http://www.ppmy.cn/news/64885.html

相关文章

ACM 1010 | 利润计算

文章目录 0x00 前言 0x01 题目描述 0x02 问题分析 0x03 代码设计 0x04 完整代码 0x05 运行效果 0x06 总结 0x00 前言 C 语言网不仅提供 C 语言&#xff0c;还包括 C 、 java 、算法与数据结构等课程在内的各种入门教程、视频录像、编程经验、编译器教程及软件下载、题解博…

系统分析师---论软件开发模型及应用

论题:论软件开发模型及应用 软件开发模型(Software Development Model)是指软件开发全部过程、活动和任务的结构框架。软件开发过程包括需求、设计、编码和测试等阶段,有时也包括维护阶段。软件开发模型能清晰、直观地表达软件开发全过程,明确规定了要完成的主要任务和活…

互联网从业者必备50个工作中必备报错

Assertion Failure: 断言失败Connection Timeout: 连接超时Error Code: 错误码Invalid Input: 无效的输入Resource Not Found: 未找到资源Server Error: 服务器错误Timeout Error: 超时错误Unable to Connect: 无法连接Unexpected Error: 意外的错误Access Denied: 访问被拒绝A…

(5)Qt—ui常用类

目录 1. QString 字符串类* 2. 容器类 2.1 顺序容器 QList 2.2关联容器 QMap 3. Qt类型 3.1 跨平台数据类型 3.2 QVariant 统一数据类型 4.QDate Time 日期时间类 5.QTimer 定时器类 1. QString 字符串类* QString是Qt中的字符串类&#xff0c;与C和C不同的是&#xff0c;Qt的…

HTML的两个实战项目

文章目录 HTML的两个实战项目1. 个人简历1. 1 快速生成模板1.2 根据简历格式进行预设计1.3 开始创作吧1.3.1 基本信息1.3.2 教育背景1.3.3 专业技能1.3.4 我的项目1.3.5 自我评价 2. 输入简历信息页面设计2.1 设计大概框架2.2 开始创作吧2.2.1 输入姓名2.2.2 上传照片2.2.3 输入…

使用【SD-WEBUI】插件生成单张图包含多个人物:分区域的提示词

文章目录 &#xff08;零&#xff09;前言&#xff08;一&#xff09;潜变量成对&#xff08;Latent Couple&#xff09;&#xff08;1.1&#xff09;可自组LoRA&#xff08;Composable LoRA&#xff09; &#xff08;二&#xff09;分区扩散&#xff08;Multi Diffusion&#…

4.共享模型之管程

4.共享模型之管程 4.1 共享带来的问题 Java的体现 import lombok.extern.slf4j.Slf4j;/*** author xc* date 2023/5/6 13:00*/ Slf4j public class Test14 {static int i 0;public static void main(String[] args) throws InterruptedException {Thread t1 new Thread(()…

Redis 缓存穿透、缓存击穿与缓存雪崩

文章目录 1. 缓存穿透解决方法 2. 缓存击穿解决方法 3. 缓存雪崩解决方法 在 redis 的应用场景中&#xff0c;需要考虑缓存在某些场景下可能出现的问题&#xff1a; 缓存穿透 缓存击穿 缓存雪崩 以下缓存问题的讨论都是基于以下应用架构讨论的&#xff1a; 1. 缓存穿透 对应…