Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 2831|回复: 7

[已解决]表格合并

[复制链接]
发表于 2015-4-14 10:19 | 显示全部楼层 |阅读模式
将两个表格合并在一个表格的取值问题。
最佳答案
2015-4-14 13:34
Sub Click()
    Dim d, A, B
    Dim i, j, k

    '1)创建
    Set d = CreateObject("scripting.dictionary")
    For k = 1 To 2
        A = Sheets(k).Range("a1").CurrentRegion
        For i = 2 To UBound(A)
            If d.exists(A(i, 2)) Then
                For j = 1 To UBound(A, 2)
                    If A(i, j) = "" Then A(i, j) = "的"
                    If Asc(d(A(i, 2))(A(1, j))) < Asc(A(i, j)) Then d(A(i, 2))(A(1, j)) = A(i, j)    '比较
                Next j
            Else
                Set d(A(i, 2)) = CreateObject("scripting.dictionary")    '字典嵌套
                For j = 1 To UBound(A, 2)
                    If A(i, j) = "" Then A(i, j) = "的"
                    d(A(i, 2))(A(1, j)) = A(i, j)
                Next j
            End If
        Next i
    Next k

    '2)查询
    ReDim A(1 To d.Count + 1, 1 To UBound(A, 2))
    For j = 1 To UBound(A, 2)
        A(1, j) = Sheets(1).Cells(1, j)
    Next j
    B = d.keys
    For i = 2 To UBound(A)
        For j = 1 To UBound(A, 2)
            A(i, j) = d(B(i - 2))(A(1, j))
            If A(i, j) = "的" Then A(i, j) = ""
        Next j
    Next i

    '3)输出
    Sheets(3).Range("a1").CurrentRegion = ""
    Sheets(3).Range("a1").Resize(UBound(A), UBound(A, 2)) = A
End Sub
样表3.rar (21.19 KB, 下载次数: 13)

样表.rar

2.44 KB, 下载次数: 11

excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2015-4-14 10:28 | 显示全部楼层
这个有点复杂了,不太懂,如果需要的话也是可以的!
回复

使用道具 举报

 楼主| 发表于 2015-4-14 10:36 | 显示全部楼层
就是两次考试,考试成绩分为优秀、合格、不合格。有的人参加了两次考试,有的人参加了一次考试,我们将两次考试成绩汇总,如果两次考试中有一次考试为优秀的话,就取优秀,依次类推。
回复

使用道具 举报

发表于 2015-4-14 10:37 | 显示全部楼层
就是取两次成绩中好的一次,是把?
回复

使用道具 举报

 楼主| 发表于 2015-4-14 10:40 | 显示全部楼层
回复

使用道具 举报

发表于 2015-4-14 10:40 | 显示全部楼层
看你想要什么效果了,这个方法有很多!用电辅助列,用电函数应该就可以达到效果了
回复

使用道具 举报

 楼主| 发表于 2015-4-14 10:43 | 显示全部楼层
回复

使用道具 举报

发表于 2015-4-14 13:34 | 显示全部楼层    本楼为最佳答案   
Sub Click()
    Dim d, A, B
    Dim i, j, k

    '1)创建
    Set d = CreateObject("scripting.dictionary")
    For k = 1 To 2
        A = Sheets(k).Range("a1").CurrentRegion
        For i = 2 To UBound(A)
            If d.exists(A(i, 2)) Then
                For j = 1 To UBound(A, 2)
                    If A(i, j) = "" Then A(i, j) = "的"
                    If Asc(d(A(i, 2))(A(1, j))) < Asc(A(i, j)) Then d(A(i, 2))(A(1, j)) = A(i, j)    '比较
                Next j
            Else
                Set d(A(i, 2)) = CreateObject("scripting.dictionary")    '字典嵌套
                For j = 1 To UBound(A, 2)
                    If A(i, j) = "" Then A(i, j) = "的"
                    d(A(i, 2))(A(1, j)) = A(i, j)
                Next j
            End If
        Next i
    Next k

    '2)查询
    ReDim A(1 To d.Count + 1, 1 To UBound(A, 2))
    For j = 1 To UBound(A, 2)
        A(1, j) = Sheets(1).Cells(1, j)
    Next j
    B = d.keys
    For i = 2 To UBound(A)
        For j = 1 To UBound(A, 2)
            A(i, j) = d(B(i - 2))(A(1, j))
            If A(i, j) = "的" Then A(i, j) = ""
        Next j
    Next i

    '3)输出
    Sheets(3).Range("a1").CurrentRegion = ""
    Sheets(3).Range("a1").Resize(UBound(A), UBound(A, 2)) = A
End Sub
样表3.rar (21.19 KB, 下载次数: 13)
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-27 08:07 , Processed in 0.367943 second(s), 11 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表