Excel·VBA数组平均分组问题

看到一个帖子《excel吧-数据分组问题》,对一组数据分成4组,使每组的和值相近

上一篇文章《Excel·VBA数组分组问题》,解决了这个帖子问题的第1步,即获取所有数组分组形式的问题

接下来要获取分组和值最相近的一组,只需计算每种分组形式的方差,获取方差最小的及其对应的行号,就可获取分组和值最相近的一组

先调用函数获取和值计算方差及对应的行号,再调用函数获取字符串组成形式,输出行号对应的结果

vbnet 复制代码
Sub 平均分组()
    '计算方差vba工作表函数Var_P,与365VARPA函数等价
    Dim arr, brr, crr, b, i&, j&, f, min_f
    arr = [a1].CurrentRegion: m = 4  '待分组数组,分为m组
    brr = 数组分组(arr, m, 1): crr = 数组分组(arr, m, 2): tm = Timer
    For i = 1 To UBound(brr)
        b = Application.Index(brr, i): f = WorksheetFunction.Var_P(b)
        If Len(min_f) = 0 Then min_f = f: j = i
        If min_f > f Then min_f = f: j = i
    Next
    [c1].Resize(1, m) = Application.Index(crr, j)
    Debug.Print "累计用时" & Format(Timer - tm, "0.00")  '耗时
End Sub
  • 由于这组数据数值差异较小,因此数组分组函数last_row参数为1,仅计算最后一种分组形式即可获取方差最小的结果。方差最小值为85042.60
9个元素分成4组 last_row为1 last_row为0
变量j的值 2458 13378
耗时秒数 11.79 71.33
相关推荐
笨蛋不要掉眼泪3 小时前
SpringBoot项目Excel成绩录入功能详解:从文件上传到数据入库的全流程解析
java·vue.js·spring boot·后端·spring·excel
2501_930707785 小时前
C#:将Excel转换为HTML时将图像嵌入HTML中
excel
咬尾巴的猫在coding5 小时前
pandas读取和写入excel
excel·pandas
mudtools7 小时前
.net操作Excel:图表 (Chart) 的创建与定制
c#·.net·excel·wps
码农学院7 小时前
Excel批量导入到数据库的方法
数据库·oracle·excel
云澈ovo15 小时前
AI+传统工作流:Photoshop/Excel的智能插件开发指南
人工智能·excel·photoshop
少陽君1 天前
两个表格(Excel/CSV)字段不完全一致,要合并在一起
excel
Excel_easy1 天前
Excel文件瘦身指南:快速瘦身,告别卡顿-Excel易用宝
excel
刘火锅1 天前
Java读取Excel图片技术详解:悬浮式与嵌入式图片的三种实现方案(支持WPS嵌入和Office Excel嵌入)
java·excel·wps
未来之窗软件服务1 天前
万象EXCEL开发(二)格式解读sharedStrings.xml——东方仙盟练气期
xml·excel·仙盟创梦ide·东方仙盟·万象excel·东方仙盟格式