比较两个工作簿中的行列表,并使用列表1中缺失的行更新列表2 - Excel VBA
创始人
2024-12-14 05:00:17
0

以下是一个示例代码,演示如何比较两个工作簿中的行列表,并使用列表1中缺失的行更新列表2。

Sub UpdateRows()
    Dim wb1 As Workbook, wb2 As Workbook
    Dim ws1 As Worksheet, ws2 As Worksheet
    Dim lastRow1 As Long, lastRow2 As Long
    Dim rng1 As Range, rng2 As Range, cell As Range
    Dim rowToCopy As Range, copyRange As Range
    
    '打开工作簿1和工作簿2
    Set wb1 = Workbooks.Open("路径\工作簿1.xlsx")
    Set wb2 = Workbooks.Open("路径\工作簿2.xlsx")
    
    '设置工作表1和工作表2
    Set ws1 = wb1.Worksheets("工作表1")
    Set ws2 = wb2.Worksheets("工作表2")
    
    '获取工作表1和工作表2的最后一行
    lastRow1 = ws1.Cells(ws1.Rows.Count, "A").End(xlUp).Row
    lastRow2 = ws2.Cells(ws2.Rows.Count, "A").End(xlUp).Row
    
    '设置工作表1和工作表2的范围
    Set rng1 = ws1.Range("A2:A" & lastRow1)
    Set rng2 = ws2.Range("A2:A" & lastRow2)
    
    '循环遍历工作表1的每一行
    For Each cell In rng1
        '检查工作表2是否包含当前行
        If Application.WorksheetFunction.CountIf(rng2, cell.Value) = 0 Then
            '如果工作表2中不包含当前行,则将行添加到更新范围
            If rowToCopy Is Nothing Then
                Set rowToCopy = cell.EntireRow
            Else
                Set rowToCopy = Union(rowToCopy, cell.EntireRow)
            End If
        End If
    Next cell
    
    '复制更新范围到工作表2
    If Not rowToCopy Is Nothing Then
        rowToCopy.Copy ws2.Cells(lastRow2 + 1, "A")
    End If
    
    '关闭工作簿1和工作簿2
    wb1.Close SaveChanges:=False
    wb2.Close SaveChanges:=True
End Sub

请将代码中的“路径\工作簿1.xlsx”和“路径\工作簿2.xlsx”替换为实际的工作簿路径和名称。此代码假设工作表1和工作表2在工作簿中的名称分别为“工作表1”和“工作表2”。

此代码将遍历工作表1的每一行,并检查工作表2是否包含相同的行。如果工作表2中不包含某一行,则将该行添加到更新范围。最后,将更新范围中的行复制到工作表2的末尾。

请注意,此代码假设行列表位于工作表的第一列,并且行列表中不包含重复项。如果行列表位于不同的列或包含重复项,需要稍作修改代码。

相关内容

热门资讯

Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...
Aksnginxdomainb... 在AKS集群中,可以使用Nginx代理服务器实现根据域名进行路由。以下是具体步骤:部署Nginx i...
AddSingleton在.N... 在C#中创建Singleton对象通常是通过私有构造函数和静态属性来实现,例如:public cla...
Alertmanager中的基... Alertmanager中可以使用repeat_interval选项指定在一个告警重复发送前必须等待...