利用 Excel 函数随机抽取(附示例)

RANDARRAY 是 Excel 365 和 Excel 2021 引入的一个函数,用于生成一个随机数数组。它的语法如下:

复制代码
RANDARRAY([rows], [columns], [min], [max], [whole_number])

参数详解

  1. rows(可选)

    • 要生成的行数(默认值为 1)。
    • 例如,2 表示生成 2 行的随机数。
  2. columns(可选)

    • 要生成的列数(默认值为 1)。
    • 例如,1 表示每行只有 1 列。
  3. min(可选)

    • 随机数的最小值(默认值为 0)。
    • 例如,1 表示随机数最小是 1。
  4. max(可选)

    • 随机数的最大值(默认值为 1)。
    • 例如,24 表示随机数最大是 24。
  5. whole_number(可选)

    • TRUE:生成整数随机数。
    • FALSE(默认):生成小数随机数。

在随机抽奖中的应用

你的需求是 从 B2:B25 随机抽取 2 人,所以公式是:

复制代码
=INDEX(B2:B25, RANDARRAY(2, 1, 1, ROWS(B2:B25), TRUE))
  • 2 → 生成 2 行(抽 2 人)
  • 1 → 每行 1 列
  • 1 → 随机数最小是 1(对应 B2)
  • ROWS(B2:B25) → 计算 B2:B25 的行数(24),作为最大值
  • TRUE → 生成整数(避免小数索引)

这样,RANDARRAY 会生成 2 个 1~24 的随机整数INDEX 再用它们从 B2:B25 中取出对应名字。


注意事项

  1. 避免重复抽中同一人
    RANDARRAY 可能会生成相同的随机数(即同一个人被抽中两次)。
    解决方法(确保不重复):

    复制代码
    =LET(
        randNums, RANDARRAY(24, 1, 1, 24, TRUE),
        uniqueRand, UNIQUE(randNums),
        INDEX(B2:B25, TAKE(uniqueRand, 2))
    )
    • UNIQUE 确保随机数不重复
    • TAKE(uniqueRand, 2) 取前 2 个不重复的随机数
  2. 每次计算都会刷新

    • F9 或编辑单元格时,随机结果会重新生成。
    • 如果想固定结果,可以 复制 → 右键 → "粘贴为值"

总结

参数 作用 示例值
rows 生成的行数 2(抽 2 人)
columns 生成的列数 1(单列)
min 随机数最小值 1(从第 1 行开始)
max 随机数最大值 24(共 24 个名字)
whole_number 是否取整数 TRUE(避免小数索引)


示例 下载 地址

相关推荐
wefg14 小时前
【算法】分治
数据结构·算法·排序算法
想唱rap4 小时前
归并排序、计数排序以及各种排序稳定性总结
c语言·数据结构·笔记·算法·新浪微博
User_芊芊君子6 小时前
【Java ArrayList】底层方法的自我实现
java·开发语言·数据结构
敲代码的嘎仔6 小时前
牛客算法基础noob56 BFS
java·开发语言·数据结构·程序人生·算法·宽度优先
今后1238 小时前
【数据结构】堆、计数、桶、基数排序的实现
数据结构·算法·堆排序·计数排序·桶排序·基数排序
敲代码的嘎仔8 小时前
牛客算法基础noob59 简写单词
java·开发语言·数据结构·程序人生·算法·leetcode·学习方法
白水先森19 小时前
C语言作用域与数组详解
java·数据结构·算法
想唱rap19 小时前
直接选择排序、堆排序、冒泡排序
c语言·数据结构·笔记·算法·新浪微博
@小红花21 小时前
数据分析-Excel-常用函数
数据挖掘·数据分析·excel
YuTaoShao21 小时前
【LeetCode 每日一题】2221. 数组的三角和
数据结构·算法·leetcode