VBA提高篇_ 21 随机数 / 模运算

news2024/11/26 13:49:57

文章目录

    • 1. 模Mod运算
    • 2. 随机数及其运算
      • 2.1 Rnd()函数
      • 调用Excel公式: Rand() / RandBetween()
      • 使用VBA函数: Rnd()函数
      • 2.2 随机小数化整数公式
      • 2.3 伪随机数(过程是随机的,但是实际上不是,随机数算法)
        • 2.3.1 随机数初始化
        • 2.3.2 随机小数被当做下标时会被自动四舍五入

  1. VBA的默认属性Value
  2. Set关键字
    • Cells(1,1) 可以代表Range对象,也可以代表Cells(1,1)的值(Value),所以必须使用Set关键字

1. 模Mod运算

  1. 实现__有序__周期性变化,可以考虑使用模运算

    • 取的模(余数)–永远不可能比除数更大
    • 换言之: 余数一定小于除数----除数运算法则(初中知识)
  2. 取模运算可以作循环使用(示例: 余数一定小于除数 i / 4 = j···0/1/2/3)

Sub colorSize()
    Dim myColor(3) As Long, i As Integer
    
    myColor(0) = vbRed: myColor(1) = vbYellow
    myColor(2) = vbBlue: myColor(3) = vbGreen
    
    i = 1
    Do While Cells(i, 1) <> ""
        Cells(i, 1).Resize(1, 4).Interior.Color = myColor((i - 1) Mod 4)

        i = i + 1
    Loop
    
    
End Sub
  1. 判断奇偶数的方法:i mod 2 = 1
Sub 判断奇偶数()
    Dim i%
    i = 7
    If i Mod 2 = 0 Then
        MsgBox i & "是偶数"
    Else
        MsgBox i & "是奇数"
    End If
End Sub

2. 随机数及其运算

2.1 Rnd()函数

  1. 实现__随机__周期性变化,可以考虑使用随机数及其相关运算

调用Excel公式: Rand() / RandBetween()

  • (Excel.Application).WorkSheetFunction.Rand/RandBetween

使用VBA函数: Rnd()函数

  • Rnd()函数: 0-1之间的随机小数 (Ps: 数组下标可以自动对小数的四舍五入,进行取整操作)

在这里插入图片描述

2.2 随机小数化整数公式

  • 生成[a,b]区间的随机整数的公式: Int(Rnd() * (b - a + 1) + a )

2.3 伪随机数(过程是随机的,但是实际上不是,随机数算法)

计算伪随机数时,假如使用的开始值(种子)不变,那么生成的随机数序也不变

在这里插入图片描述

2.3.1 随机数初始化

- **Randomize**(每次随机数运行前执行,程序运行前只需要一次,不能放在循环里)

在这里插入图片描述

2.3.2 随机小数被当做下标时会被自动四舍五入

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/336322.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

BERT简介

BERT&#xff1a; BERT预训练模型训练步骤&#xff1a; 使用Masked LM方式将语料库中的某一部分的词语掩盖住&#xff0c;模型通过上下文预测被掩盖的信息&#xff0c;从而训练出初步的语言模型在语料库中选出连续的上下语句&#xff0c;并使用Tranformer模块识别语句的连续性通…

PHP基于TCPDF第三方类生成PDF文件

最近在研发招聘的系统 遇到了这个问题 转换pdf 折腾了很久 分享一下PHP基于TCPDF第三方类生成PDF文件最近遇到一个需求&#xff0c;需要根据数据库的字段生成表格式的PDF文件并发送邮箱第一步、我们先去官网上面去下载tcpdf的类&#xff1a;http://www.tcpdf.org/或者是从githu…

LightGBM

目录 1.LightGBM的直方图算法(Histogram) 直方图做差加速 2.LightGBM得两大先进技术(GOSS&EFB) 2.1 单边梯度抽样算法(GOSS) 2.2 互斥特征捆绑算法(EFB) 3.LightGBM得生长策略(leaf-wise) 通过与xgboost对比&#xff0c;在这里列出lgb新提出的几个方面的技术 1.Ligh…

JavaScript 评测代码运行速度的几种方法

一、使用 performance.now() API 在 JavaScript 中&#xff0c;可以使用 performance.now() API 来评测代码的运行速度。该 API 返回当前页面的高精度时间戳&#xff0c;您可以在代码执行前后调用它来计算代码执行所需的时间。 例如&#xff1a; let t0 performance.now();…

计算机组成与设计04——处理器

系列文章目录 本系列博客重点在深圳大学计算机系统&#xff08;3&#xff09;课程的核心内容梳理&#xff0c;参考书目《计算机组成与设计》&#xff08;有问题欢迎在评论区讨论指出&#xff0c;或直接私信联系我&#xff09;。 第一章 计算机组成与设计01——计算机概要与技…

idea整合svn

idea整合svn svn下载 链接&#xff1a;https://pan.baidu.com/s/1yS3R3lEE8lm9c9Ap-ndDKg 提取码&#xff1a;65ur 基础步骤 IDED中配置SVN没有svn.exe解决办法 以下是两种解决方案 需要卸载原 svn&#xff08;不推荐&#xff09; 参考网址&#xff1a; https://blog.csdn.…

ansible以及playbook

文章目录1.ansible1.概念2.工作原理3.安装ansible2.playbook1.组件2.角色详解3.剧本语法3.1基本语法3.2常用字段3.3 选项1.ansible 1.概念 ansible是一个可以服务端控制其他机器完成工作的一个应用工具&#xff0c; 1.服务没有客户端存在&#xff0c;通过模块对节点服务器进行…

设计模式--建造者模式 builder

设计模式--建造者模式 builder&#xff09;建造者模式简介建造者模式--小例子&#xff08;电脑购买&#xff09;1.产品类2.抽象构建者3.实体构建类4.指导者类5.客户端测试类小结建造者模式简介 建造者模式有四个角色,概念划分如下&#xff1a; Product &#xff1a; 产品类&a…

docker的基本管理

Docker的概念云计算三层架构服务说明应用IAAS基础设施及服务硬件&#xff08;服务器、网络设置、防火墙等&#xff09;虚拟化网络虚拟化&#xff08;大二层&#xff09;例&#xff1a;openstackPAAS平台及服务环境例&#xff1a;数据库、 docker 、kubernetesSAAS应用及服务应用…

内网渗透(十四)之内网信息收集-域环境中查找域内用户基本信息

系列文章第一章节之基础知识篇 内网渗透(一)之基础知识-内网渗透介绍和概述 内网渗透(二)之基础知识-工作组介绍 内网渗透(三)之基础知识-域环境的介绍和优点 内网渗透(四)之基础知识-搭建域环境 内网渗透(五)之基础知识-Active Directory活动目录介绍和使用 内网渗透(六)之基…

终于进了字节,记录一下我作为一名测试员磕磕碰碰的三个月找工作经历...

我是裸辞后重新找工作的&#xff0c;从去年到今年&#xff0c;前前后后花了大概三个月&#xff0c;大大小小参加了几百场面试。不是我说&#xff0c;作为一名测试员是真的挺难的&#xff0c;不过很庆幸自己最后拿到了字节的offer&#xff0c;今天在这里做一下记录吧&#xff0c…

从GPT到ChatGPT:我们离那个理想的AI时代到底还有多远?

写在前面 在2023年新年伊始&#xff0c;科技界最为爆火一款产品无疑是OpenAI公司出品的ChatGPT了&#xff0c;作为一名NLP领域从业者&#xff0c;似乎也好久没有看到如此热闹的技术出圈场景了。诚然从现象来看&#xff0c;无论从效果惊艳度、社会效应、商业价值、科技发展方向…

C++【多态】

文章目录1、多态的概念2、多态的定义及实现2-1、多态的构成条件2-2、虚函数2-3、虚函数的重写2-4 多态样例2-5、协变2-6、 析构函数与virtual2-7、函数重载、函数隐藏&#xff08;重定义&#xff09;与虚函数重写&#xff08;覆盖&#xff09;的对比2-8、override 和 final&…

spring的简单理解

目录 1 .ioc容器&#xff08;控制反转&#xff09; 2. Aop面向切面编程 3. 事务申明 4. 注解的方式启动 5. spring是什么与他的优势 6. 代理设计模式&#xff08;比如aop&#xff09; 7. springmvc中相应json数据 8. 使用lombok来进行对代码的简化 9. 使用logback记录…

学习SpringCloudAlibaba(二)微服务的拆分与编写

目录 一、单体架构VS微服务架构 1.单体架构 ​&#xff08;1&#xff09;.单体架构的优点 &#xff08;2&#xff09;.单体架构的缺点 2.微服务架构 &#xff08;1&#xff09;微服务的特性 &#xff08;2&#xff09;微服务架构图 &#xff08;3&#xff09;微服务的优点 …

大数据之------------数据中台

一、什么是数据中台 **数据中台是指通过数据技术&#xff0c;对海量数据进行采集、计算、存储、加工&#xff0c;同时统一标准和口径。**数据中台的目标是让数据持续用起来&#xff0c;通过数据中台提供的工具、方法和运行机制&#xff0c;把数据变为一种服务能力&#xff0c;…

ChatGPT使用、原理及问题

引言 2022年11月30日&#xff0c;OpenAI公布了他们的新产品&#xff1a;ChatGPT。随后ChatGPT火得一塌糊涂。通过b站搜索“ChatGPT”的结果&#xff1a; 搞学术的想着从它身上找点创新&#xff0c;吃瓜群众吃着这锅热瓜&#xff0c;想赚钱的眼睛贼亮&#x1f31f;&#x1f31f…

C++11中function和bind的用法

C11中function和bind的用法一、简介二、std::function的用法2.1、保存普通函数2.2、保存lambda表达式2.3、保存成员函数三、std::bind用法总结一、简介 在设计回调函数的时候&#xff0c;无可避免地会接触到可回调对象。在C11中&#xff0c;提供了std::function和std::bind两个…

云端IDE系列教程6:初识 WeTTY,想说爱你不容易

原文作者&#xff1a;行云创新产品总监 John 概述 今天我们接着上一期的文章《玩转云原生 Terminal 之 TTY 的前世今生》&#xff0c;继续来聊一聊云原生 Terminal。为了在 TitanIDE 上玩转云原生 Terminal &#xff0c;首先找到了 WeTTY&#xff0c;在这个过程中&#xff0c;…

ITSM | 限时优惠,帮助您的团队终结不良服务管理!

不良服务管理&#xff08;Bad Service Management &#xff0c;简称BSM&#xff09;是一种糟糕的状况&#xff0c;困扰着使用传统ITSM工具的公司。现在&#xff0c;它已经在许多IT团队中蔓延&#xff0c;并迅速攻击业务的其他领域&#xff0c;使他们无法处理来自不同业务领域的…