概要:在 Microsoft Excel 中,可以创建宏来删除列表中的重复项。也可以创建宏来比较两个列表,并删除第二个列表中那些也出现在第一个(主)列表中的项目。如果您想将两个列表合并在一起,或者如果只想看到新的信息,则上述做法很有用。本文包含 Microsoft Visual Basic for Applications 示例宏(Sub 过程),说明如何删除单个列表中的重复记录(示例 1),以及如何在比较两个列表后删除重复记录(示例 2)。这些宏并不要求对列表进行排序。此外,这些宏可删除任意数量的重复项,无论项目在列表中是重复一次还是多次。

Excal数据示例如下:

序号      图号     名称      数量
 1        123    气缸盖     10
 2        123    气缸盖     10
 3        456    喷油器     30

对于这段数据进行简单处理,删除序号1或者2其中的任何一行均可,但是要保留其中一行

  1. Sub 删除重复行()
  2. Dim xRow As Integer
  3. Dim i As Integer
  4. xRow = Range("B65536").End(xlUp).Row
  5. For i = To xRow
  6. For j = i + To xRow
  7. If Cells(j, ) = Cells(i, ) Then
  8. Range(Cells(j, ), Cells(j, )).Rows.Delete
  9. j = j -
  10. xRow = xRow -
  11. End If
  12. Next
  13. Next
  14. End Sub

输入上述代码,运行该代码或运行宏“删除重复行”即可。有个缺陷,只是判断图号相同即删除,假如图号相同、数量不同的行照样删除。

示例 1:删除单个列表中的重复项

以下示例宏搜索区域 A1:A100 中的单个列表,并删除列表中的所有重复项。此宏要求在列表区域中不能有空白单元格。如果列表确实包含空白单元格,请按升序对数据进行排序,以使空白单元格全都位于列表的末尾。

  1. Sub DelDups_OneList()
  2. Dim iListCount As Integer
  3. Dim iCtr As Integer
  4.  
  5. ' Turn off screen updating to speed up macro.
  6. Application.ScreenUpdating = False
  7.  
  8. ' Get count of records to search through.
  9. iListCount = Sheets("Sheet1").Range("A1:A100").Rows.Count
  10. Sheets("Sheet1").Range("A1").Select
  11. ' Loop until end of records.
  12. Do Until ActiveCell = ""
  13. ' Loop through records.
  14. For iCtr = To iListCount
  15. ' Don't compare against yourself.
  16. ' To specify a different column, change 1 to the column number.
  17. If ActiveCell.Row <> Sheets("Sheet1").Cells(iCtr, ).Row Then
  18. ' Do comparison of next record.
  19. If ActiveCell.Value = Sheets("Sheet1").Cells(iCtr, ).Value Then
  20. ' If match is true then delete row.
  21. Sheets("Sheet1").Cells(iCtr, ).Delete xlShiftUp
  22. ' Increment counter to account for deleted row.
  23. iCtr = iCtr +
  24. End If
  25. End If
  26. Next iCtr
  27. ' Go to next record.
  28. ActiveCell.Offset(, ).Select
  29. Loop
  30. Application.ScreenUpdating = True
  31. MsgBox "Done!"
  32. End Sub

示例 2:比较两个列表并删除重复项

以下示例宏将一个(主)列表与另一个列表进行比较,然后删除第二个列表中那些也出现在主列表中的重复项。第一个列表在 Sheet1 上的区域 A1:A10 中。第二个列表在 Sheet2 上的区域 A1:A100 中。要使用此宏,请选择任一个表,然后运行此宏。

  1. Sub DelDups_TwoLists()
  2. Dim iListCount As Integer
  3. Dim iCtr As Integer
  4.  
  5. ' Turn off screen updating to speed up macro.
  6. Application.ScreenUpdating = False
  7.  
  8. ' Get count of records to search through (list that will be deleted).
  9. iListCount = Sheets("sheet2").Range("A1:A100").Rows.Count
  10.  
  11. ' Loop through the "master" list.
  12. For Each x In Sheets("Sheet1").Range("A1:A10")
  13. ' Loop through all records in the second list.
  14. For iCtr = To iListCount
  15. ' Do comparison of next record.
  16. ' To specify a different column, change 1 to the column number.
  17. If x.Value = Sheets("Sheet2").Cells(iCtr, ).Value Then
  18. ' If match is true then delete row.
  19. Sheets("Sheet2").Cells(iCtr, ).Delete xlShiftUp
  20. ' Increment counter to account for deleted row.
  21. iCtr = iCtr +
  22. End If
  23. Next iCtr
  24. Next
  25. Application.ScreenUpdating = True
  26. MsgBox "Done!"
  27. End Sub

在 Excel 中如何使用宏示例删除列表中的重复项的更多相关文章

  1. for循环删除列表中元素遇到的漏删的问题(python)

    问题描述:python中通过for循环来删除列表中的两个相邻的元素,存在漏删的问题 比如说下面的例子,准备删掉2和3,但是结果是2删掉了,3没删掉 是因为把2删掉后3的下标就变成了1,但是原本下标为1 ...

  2. React 点击删除列表中对应项(React 获取DOM中自定义属性)

    点击删除按钮,删除列表中对应项本来是React比较基础的应用,可是应用情况变得复杂了以后,我还真想了一会儿才搞定. 简化一下应用场景:点击新增按钮,增加一条输入框,点击输入框旁边的按钮,删除该输入框( ...

  3. python中循环删除列表中元素时的坑!

    循环删除列表中元素时千万别用正序遍历,一定要用反序遍历! 废话不多说,先上案例代码: def test(data): for i in data: data.remove(i) return data ...

  4. python中如何删除列表中的所有元素

    今天写代码的时候遇到一个小问题,Python中要删除列表中的所有元素.Python本身就提供了pop.remove.del这些删除的函数.我想着用循环实现,结果很麻烦.几番周折上了stackoverf ...

  5. Python删除列表中元素

    Python中列表(list)是很常用的数据结构,删除列表中的元素有几种方法 列表的remove方法 lst = [1, 1, 3, 4] lst.remove(1) # lst->[1, 3, ...

  6. python删除列表中元素的方法

    删除列表中元素的三种方法-remove.pop.del 1 1.remove: 删除单个元素,删除首个符合条件的元素,按值删除 2 举例说明: 3 >>> str=[1,2,3,4, ...

  7. python删除列表中得重复得数据

    解决思想:将列表转换为 集合,利用集合删除重复数据得特性删除重复数据,然后将集合转换为列表 #删除列表中得重复元素 def delect_1 (lt): s = set(lt) lt = list(s ...

  8. python——删除列表中的元素

    在python中,删除列表元素的方法有三种,分别为remove(),del(),pop()函数 (1)remove() >>> name = ['小明','小华','小红','小李' ...

  9. Delphi for iOS开发指南(6):在iOS应用程序中使用ComboBox组件来从列表中选择某一项

    http://blog.csdn.net/delphiteacher/article/details/8924110 Delphi for iOS开发指南(6):在iOS应用程序中使用ComboBox ...

随机推荐

  1. QT代理Delegates使用实例(三种代理控件)

    效果如下,在表格的单元格中插入控件,用Delegates方式实现 源代码如下: main.cpp文件 #include <QApplication>#include <QStanda ...

  2. HDU 5072 Coprime 同色三角形问题

    好吧,我承认就算当时再给我五个小时我也做不出来. 首先解释同色三角形问题: 给出n(n >= 3)个点,这些点中的一些被涂上了红色,剩下的被涂上了黑色.然后将这些点两两相连.于是每三个点都会组成 ...

  3. ios开发总结,日常开发:ios开发功能收集,经验分享等等(不断更新中。。。)

    github资料学习和下载地址:https://github.com/niexiaobo/MyDailyDevelopmentNotes ios 学习模块 ios APP 日志管理的重要性: 一个功能 ...

  4. C++网络编程方面的开源项目

    Webbench是一个在linux下使用的非常简单的网站压测工具.它使用fork()模拟多个客户端同时访问我们设定的URL,测试网站在压力下工作的性能,最多可以模拟3万个并发连接去测试网站的负载能力. ...

  5. 正則表達式基础及java使用

    正則表達式基础 正則表達式语法(1)     普通字符:字母,数字.汉子,下划线以及没有特殊定义的标点符号都是"普通字符".表达式中的普通字符.在匹配一个字符串的时候,匹配与之同样 ...

  6. Qt5.4.2编译 qtpropertybrowser-2.51(从4修改到5的除错过程)

    qtpropertybrowser是一个洛基亚时代的一个产物,其实它就是QtDesigner侧栏那种样子而已.网上大部分的都只适用于Qt4,今天头脑发热想用Qt5编译一下,发觉一大堆错误,因为Qt4有 ...

  7. 阿里云服务器apache服务器局域网访问公网访问配置

    阿里云服务器apache服务器局域网访问公网访问配置 一.总结 一句话总结: 1.再总结-------------------------------------------------------- ...

  8. python 爬取bilibili 视频弹幕

    # -*- coding: utf-8 -*- # @author: Tele # @Time : 2019/04/09 下午 4:50 # 爬取弹幕 import requests import j ...

  9. svn创建版本库和删除版本库

    作者:朱金灿 来源:http://blog.csdn.net/clever101 svn创建版本库的做法:使用cd命令进入版本仓库的根目录,我的是E:\Repository,然后运行命令: svnad ...

  10. 【codeforces 787B】Not Afraid

    [题目链接]:http://codeforces.com/contest/787/problem/B [题意] -水题..题目太吓人 [题解] 只要你在一组里面找到两个数字,它们的绝对值相同,但是正负 ...