excel比较并合并工作表

时间:2022-02-05 20:27:51 

有两个工作表,均含有相同的数据,但最后一列名称和产品的数量不同,如下图1和图2所示。

excel比较并合并工作表

图1

excel比较并合并工作表

图2

现在需要将这两个工作表合并,保留最后一列且添加一列用来存放两个工作表最后一列数据之差,如下图3所示。

excel比较并合并工作表

图3

这里使用VBA来解决。

由于我们要使用Dictionary对象,因此先要设置相应对象库的引用。首先,打开VBE编辑器,单击菜单“工具——引用”,找到并选取“Microsoft Scripting Runtime”前的复选框,如下图4所示。

excel比较并合并工作表

图4

编写代码如下:

Sub CombineSheets()

‘声明变量

‘用于存储工作表Sheet1中的数据

Dim dic1 As Scripting.Dictionary

‘用于存储工作表Sheet2中的数据

Dim dic2 As Scripting.Dictionary

‘工作表Sheet1

Dim wks1 As Worksheet

‘工作表Sheet2

Dim wks2 As Worksheet

‘工作表Sheet3

Dim wks3 As Worksheet

‘工作表中数据的最后一行

Dim lngLastRow As Long

Dim i As Long

Dim j As Long

Dim var As Variant

‘入库数量

Dim dblImport As Double

‘出库数量

Dim dblExport As Double

Dim rng1 As Range

Dim rng2 As Range

‘赋值工作表对象

Set wks1 = Sheets(“Sheet1”)

Set wks2 = Sheets(“Sheet2”)

Set wks3 = Sheets(“Sheet3”)

‘初始化字典对象

Set dic1 = New Scripting.Dictionary

Set dic2 = New Scripting.Dictionary

‘填充字典dic1

lngLastRow = wks1.Range(“A” &Rows.Count).End(xlUp).Row

Set dic1 =DicData(wks1.Range(“A1:E” & lngLastRow), 2, True)

‘填充字典dic2

lngLastRow = wks2.Range(“A” &Rows.Count).End(xlUp).Row

Set dic2 = DicData(wks2.Range(“A1:E”& lngLastRow), 2, True)

‘将数据输入到工作表Sheet3

wks3.Rows(“2:” &Rows.Count).Clear

i = 1

‘遍历字典dic1

For Each var In dic1.Keys

dblImport = 0

‘取第5列中的入库数据并求和

For Each rng1 In dic1.Item(var).Rows

dblImport = dblImport +rng1.Cells(5)

Next rng1

‘输出数据到相应的单元格

i = i + 1

For Each rng2 Indic1.Item(var).Rows(1).Cells

wks3.Cells(i, rng2.Column) = rng2

Next rng2

wks3.Cells(i, 5) = dblImport

wks3.Cells(i, 1) = i – 1

Next var

For Each var In dic2.Keys

dblExport = 0

‘取第5列中的出库数据并求和

For Each rng1 In dic2.Item(var).Rows

dblExport = dblExport +rng1.Cells(5)

Next rng1

‘输出数据到相应的单元格中并计算出入库差

lngLastRow = wks3.Range(“A”& Rows.Count).End(xlUp).Row

For j = 2 To lngLastRow

If dic2.Item(var).Cells(1, 2) =wks3.Cells(j, 2) Then

wks3.Cells(j, 6) = dblExport

wks3.Cells(j, 7).Formula =”=” & _

wks3.Cells(j, 5).Address& “-” & _

wks3.Cells(j, 6).Address

Exit For

End If

Next j

Next var

End Sub

‘使用指定区域的数据填充字典

Function DicData(rngInput AsRange, _

ColIndex As Long, _

blnHeaders As Boolean) AsScripting.Dictionary

Dim i As Long

Dim cell As Range

Dim rng As Range

Dim rngTemp As Range

Dim dic As Scripting.Dictionary

Dim strVal As String

Application.ScreenUpdating = False

Set rng = rngInput.Columns(ColIndex)

Set dic = New Scripting.Dictionary

‘文本比较,不区分大小写

dic.CompareMode = TextCompare

‘是否有标题

If blnHeaders Then

With rngInput

Set rngInput = .Offset(1,0).Resize( _

.Rows.Count – 1, .Columns.Count)

End With

End If

With rngInput

For Each cell In.Columns(ColIndex).Cells

i = i + 1

strVal = cell.Text

If Not dic.Exists(strVal) Then

dic.Add strVal, .Rows(i)

Else

‘将前几列具有相同数据的行存储在同一字典键

Set rngTemp = Union(.Rows(i),dic(strVal))

dic.Remove strVal

dic.Add strVal, rngTemp

End If

Next cell

End With

Set DicData = dic

Application.ScreenUpdating = True

End Function

运行代码后,即可得到上图3所示的结果。

代码的图片版如下:

excel比较并合并工作表

标签:excel图表制作,excel常用函数,excel数据透视表,Excel教程
0
投稿

猜你喜欢

  • word标题样式怎么设置?

    2022-01-20 04:26:05
  • win10整个屏幕变蓝如何解决?win10屏幕变蓝解决教程

    2023-10-02 15:16:29
  • 关于Word的自由旋转的用法

    2022-07-19 07:46:30
  • WPS怎样制作圆形放大镜效果

    2023-10-01 05:40:22
  • word如何去水印

    2023-11-15 16:09:18
  • 实现快捷排版用Word格式跟踪

    2022-08-14 17:15:03
  • Excel数据分列的详细使用方法

    2023-09-30 03:27:18
  • ​Word怎么选中并进行翻译

    2023-11-16 13:23:44
  • word2003背景色怎么去掉?

    2023-08-30 21:06:43
  • Word表格制作技巧,制作表格超实用!

    2023-09-04 16:56:38
  • Word怎样把两个表格合并成一个表格

    2023-12-13 22:50:59
  • word改错时为什么打一个字后面的字就没有了

    2023-12-09 19:07:16
  • word图片版式的设置

    2023-02-11 11:01:14
  • ​Word中如何在圆圈里面打对钩

    2022-01-25 06:16:39
  • 在word文档中如何设置文字环绕图片效果

    2022-02-24 12:21:55
  • Word2010怎样创建自定义表格样式

    2023-12-09 12:24:45
  • Excel打印工作表,一页放不下,两页浪费纸,怎么办?

    2023-09-11 03:41:37
  • win10有没有安全模式?win10安全模式介绍

    2023-11-06 08:52:25
  • Word 2007 如何实现自动编排目录

    2023-01-27 20:26:00
  • word2013怎样设置每页字符数

    2022-10-08 13:39:28
  • asp之家 电脑教程 m.aspxhome.com