vba随机函数RND怎么用?

 我来答
黄瓜RGV
推荐于2017-09-19
知道答主
回答量:10
采纳率:0%
帮助的人:6万
展开全部
答:VBA里的随机函数是RND,在工作表中随机函数是RAND,一字之差,大家可要记好了。
RND函数的用法如下。
格式:Rnd(<数值表达式)
  功能:求(0,1)之间的一个随机数  语法:  Rnd[(number)]
  如果 number 的值是 Randomize 生成
  小于 0 ,每次都使用 number 作为随机数种子得到的相同结果。
  大于 0 ,以上一个随机数为种子产生下一个随机数。
  等于 0 ,产生与最近生成的随机数相同的随机数。
  省略, 以上一个随机数为种子产生下一个随机数。
  说明  Rnd 函数返回小于 1 但大于或等于 0 的值。
  number 的值决定了 Rnd 生成随机数的方式。
  对最初给定的种子都会生成相同的数列,因为每一次调用 Rnd 函数都用数列中的前一个数作为下一个数的种子。
  在调用 Rnd 之前,先使用无参数的Randomize
语句初始化随机数生成器(若带参数,则产生由参数对应的一个特定序列的随机数),该生成器具有根据系统计时器得到的种子。
  为了生成某个范围内的随机整数,可使用以下公式:
  Int((upperbound - lowerbound + 1) * Rnd + lowerbound)
  这里,upperbound 是随机数范围的上限,而 lowerbound 则是随机数范围的下限。
  注意 若想得到重复的随机数序列,在使用具有数值参数的 Randomize 之前直接调用具有负参数值的 Rnd。使用具有同样 number 值的 Randomize 是不会得到重复的随机数序列的。
  2、Int((upperbound - lowerbound + 1) * Rnd + lowerbound)编辑本段Rnd 函数示例
  本示例使用 Rnd 函数随机生成一个 1 到 6 的随机整数。
  DimMyValue  MyValue = Int((6 * Rnd) + 1) ' 生成 1 到 6 之间的随机数值 ,这里的int 是把后面产生的小数转换成整数
百度网友f27200e
推荐于2019-09-12 · TA获得超过2.6万个赞
知道小有建树答主
回答量:390
采纳率:100%
帮助的人:6万
展开全部

要点:

  • 取特定区间的数[a,b)表示为Int((b * Rnd) + a)

  • rnd本指取[0,1)之间的数

  • Randomize 语句初始化随机数生成器。 
    语法 
    Randomize [number] 
    可选的 number 参数是 Variant 或任何有效的数值表达式。 
    说明 
    Randomize 用 number 将 Rnd 函数的随机数生成器初始化,该随机数生成器给 number 一个新的种子值。如果省略 number,则用系统计时器返回的值作为新的种子值。 
    如果没有使用 Randomize,则(无参数的)Rnd 函数使用第一次调用 Rnd 函数的种子值)

  • 四舍五入函数Round(x1[,x2]) 
    四舍五入保留小数x2位,省略表示为取整

代码区

  • 猜数游戏

如果不使用Randomize,则随机数第一次写入内存后就不会更改,下次运行 
值不变。Randomize重在可以初始化内存中的随机数值

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
鼎尊制造happy
2019-10-11 · TA获得超过3.7万个赞
知道大有可为答主
回答量:1.2万
采纳率:28%
帮助的人:1010万
展开全部
答:VBA里的随机函数是RND,在工作表中随机函数是RAND,一字之差,大家可要记好了。
RND函数的用法如下。
格式:Rnd(<数值表达式)
  功能:求(0,1)之间的一个随机数  语法:  Rnd[(number)]
  如果
number
的值是
Randomize
生成
  小于
0
,每次都使用
number
作为随机数种子得到的相同结果。
  大于
0
,以上一个随机数为种子产生下一个随机数。
  等于
0
,产生与最近生成的随机数相同的随机数。
  省略,
以上一个随机数为种子产生下一个随机数。
  说明  Rnd
函数返回小于
1
但大于或等于
0
的值。
  number
的值决定了
Rnd
生成随机数的方式。
  对最初给定的种子都会生成相同的数列,因为每一次调用
Rnd
函数都用数列中的前一个数作为下一个数的种子。
  在调用
Rnd
之前,先使用无参数的Randomize
语句初始化随机数生成器(若带参数,则产生由参数对应的一个特定序列的随机数),该生成器具有根据系统计时器得到的种子。
  为了生成某个范围内的随机整数,可使用以下公式:
  Int((upperbound
-
lowerbound
+
1)
*
Rnd
+
lowerbound)
  这里,upperbound
是随机数范围的上限,而
lowerbound
则是随机数范围的下限。
  注意
若想得到重复的随机数序列,在使用具有数值参数的
Randomize
之前直接调用具有负参数值的
Rnd。使用具有同样
number
值的
Randomize
是不会得到重复的随机数序列的。
  2、Int((upperbound
-
lowerbound
+
1)
*
Rnd
+
lowerbound)编辑本段Rnd
函数示例
  本示例使用
Rnd
函数随机生成一个
1

6
的随机整数。
  DimMyValue  MyValue
=
Int((6
*
Rnd)
+
1)
'
生成
1

6
之间的随机数值
,这里的int
是把后面产生的小数转换成整数
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
woshidaniel
推荐于2017-10-05 · TA获得超过9241个赞
知道小有建树答主
回答量:1760
采纳率:96%
帮助的人:946万
展开全部
1~16的随机整数:Int((16 * Rnd) + 1)
1~16的随机数:15 * Rnd + 1

格式:rnd(<数值表达式)
功能:求(0,1)之间的一个随机数  语法:  rnd[(number)]
如果 number 的值是 randomize 生成
小于 0 ,每次都使用 number 作为随机数种子得到的相同结果。
大于 0 ,以上一个随机数为种子产生下一个随机数。
等于 0 ,产生与最近生成的随机数相同的随机数。
省略, 以上一个随机数为种子产生下一个随机数。
说明  rnd 函数返回小于 1 但大于或等于 0 的值。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jtnjh63
2021-01-14 · TA获得超过768个赞
知道答主
回答量:0
采纳率:0%
帮助的人:0
展开全部

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式