广告合作
  • 今日头条

    今日头条

  • 百度一下

    百度一下,你就知道

  • 新浪网

    新浪网 - 提供新闻线索,重大新闻爆料

  • 搜狐

    搜狐

  • 豆瓣

    豆瓣

  • 百度贴吧

    百度贴吧——全球领先的中文社区

  • 首页 尚未审核订阅工具 订阅

    Excel表格上面使用VBA进行数组组合

    来源:网络收集  点击:  时间:2024-08-17
    【导读】:
    如下图所示,要在A列里面的E1、E2、E3、F1、F2、F3、G1、G2、G3、H1、H2、H3共12个数中选出4个数进行组合,此时只能使用VBA程序来完成。工具/原料more电脑Excel 2010方法/步骤1/6分步阅读

    点击菜单栏上面的【开发工具】,【Visual Basic】。

    2/6

    打开VBA编辑器后,在VBA编辑器的菜单栏上面点击【插入】,【模块】。

    3/6

    在VBA代码框里面输入以下程序:

    Sub Zuhe()

    Dim i, j, k, l, m As Long

    Dim a, b, c, d As String

    m = 0 将m的初始值设为0

    Set mysheet1 = ThisWorkbook.Worksheets(Sheet1)

    For i = 1 To 12 每个数值都有12次的选择机会

    For j = 1 To 12

    For k = 1 To 12

    For l = 1 To 12

    a = mysheet1.Cells(i, 1) 将第i个单元格里面的数值赋给a

    If j i Then 如果已经选择第i个单元格里面的数值,则其他的不能再选择了

    b = mysheet1.Cells(j, 1)

    If k i And k j Then 如果已经选择第i、j个单元格里面的数值,则其他的不能再选择了

    c = mysheet1.Cells(k, 1)

    If l i And l j And l k Then 如果已经选择第i、j、k个单元格里面的数值,则其他的不能再选择了

    d = mysheet1.Cells(l, 1)

    m = m + 1

    mysheet1.Cells(m, 2) = a b c d 将选择出来的数值进行组合放到第2列

    End If

    End If

    End If

    Next

    Next

    Next

    Next

    End Sub

    4/6

    在这个数组组合程序里面,主要是For和If的嵌套使用。对于For语句而言,每个数都有12次被选择的机会;而If的作用是将前面已经选择的数进行排除掉,只选剩下的。

    5/6

    点击VBA编辑器工具栏里面的”运行“图标运行程序,也可以按下【F5】键运行程序。

    6/6

    程序运行完成之后,在Excel表格上面的第2列里面就能看到运算结果。组合的11880行与计算的组合数(C=12*11*10*9=11880)相符。

    注意事项

    个人经验,仅供参考。

    EXCEL组合
    本文关键词:

    版权声明:

    1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

    2、本站仅提供信息发布平台,不承担相关法律责任。

    3、若侵犯您的版权或隐私,请联系本站管理员删除。

    4、文章链接:http://www.1haoku.cn/art_1132267.html

    相关资讯

    ©2019-2020 http://www.1haoku.cn/ 国ICP备20009186号05-06 00:55:06  耗时:0.025
    0.0252s