今天和大家分享一个比较冷门的excel技巧,在excel中指定一个平均值,生成一组随机数。
如下图所示,在d1单元格输入指定的平均值,需要在a4:f11单元格区域内生成一组随机数。要求这些随机数的平均值要等于d1指定的值。
在a4单元格输入以下公式:
=if(average($a$4:$f$11)=$d$1,a4,randbetween(30,80)/10)
简单说下公式的意思:
randbetween函数用于生成指定区间的随机数。
先使用randbetween(30,80)生成30至80之间的随机数,再除以10,就得到3至8之间的小数。
average($a$4:$f$11)用于计算a4:f11单元格的平均值。
在a4单元格内,用if函数判断,如果a4:f11单元格的平均值等于d1单元格指定的值,就返回a4的本身的值,否则就生成3至8之间的小数。
由于公式引用了本身的值,所以输入公式后,会弹出警告对话框:
不要着急,还有一个开关需要我们打开。
依次单击【文件】【选项】【公式】,勾选【启用迭代计算】
最多迭代次数可以设置为1000,这里设置的次数越多,得到符合条件随机数的可能性就越大,但是次数过多,会增加计算量。
ok,只要我们修改d1单元格中指定的平均值,就会生成一组随机数,这些随机数的平均值就等于d1单元格的值。
需要注意,生成随机数的区间要根据指定平均值的大小适当调整。
假如指定平均值为10,而将随机数的区间设置为11至20,这个是永远不会得到预期结果的。
你也试试?