在 MS Excel 中,如何随机计算一组 5 个选项之一中的数字?
例如,在单元格 B1 中,我想要一个随机数,即 15、30、50、75 或 100。
我想要在单元格 B1:B100 中完全随机输出这 5 个数字。
我想我可以使用 rand 在单元格 A1 中生成一个随机数,然后使用一系列 > 或 < IF statements to output only one of these numbers above.
这个公式就可以做到:
=CHOOSE(RANDBETWEEN(1,5),15,30,50,75,100)
如果您想使用一系列单元格:
=INDEX($B$2:$B$6,RANDBETWEEN(1,5))
一种快速简便的方法是首先创建一个如下所示的查找列表:
然后在你的列中做一个这样的公式:
=VLOOKUP(ROUND(RAND()*10,0),$A$7:$B$16,1,FALSE)
其中
$A$7:$B$16
是您的列表所在的位置。如果您确实需要隔离它,它可以位于不同的选项卡或单独的文件上。
您也可以创建自定义 VBA 函数,但我认为这超出了您的需求。
假设您已使用要随机显示的值填充了电子表格 G 行中的第 1-5 行。您可以使用
=INDIRECT("G"&RANDBETWEEN(1,5))
随机显示其中任何一个。`INDIRECT` 允许您使用字符串引用单元格。
由于您想要单元格“G1”-“G5”,我们从“G”开始。
& 将“G”与下一个函数的值结合起来。
然后 RANDBETWEEN 函数将为我们提供一个介于我们提供的两个参数之间的数字(在本例中为 1 到 5)。
请告诉我这是否有帮助:)
实际上对我来说正确的语法是这样的:
=选择(RANDBETWEEN(1;7);500;525;550;575;600;625;650)
怎么样:
=SMALL({array containing numbers},RANDBETWEEN(1,COUNT({array containing numbers})))
例如如果你有一个包含 5 个数字的数组,你想在
$B$2:$B$6
中使用
=SMALL($B$2:$B$6,RANDBETWEEN(1,COUNT($B$2:$B$6)))
这将返回数字列表中的随机位置,数字的总频率由数组的定义大小组成。