当前位置: 首页 > news >正文

VBA代码解决方案第二十四讲:EXCEL中,如何删除重复数据行

《VBA代码解决方案》(版权10028096)这套教程是我最早推出的教程,目前已经是第三版修订了。这套教程定位于入门后的提高,在学习这套教程过程中,侧重点是要理解及掌握我的“积木编程”思想。要灵活运用教程中的实例像搭积木一样把自己喜欢的代码摆好。

这套教程共三册,一百四十七讲,内容覆盖较广,也是初级和中级间的过渡教程,改版后的内容主要是提供程序源码文件及代码修正为32位和64位兼用代码。今后一段时间会给大家陆续推出。今日的内容是VBA代码解决方案第二十四讲:EXCEL中,如何删除重复数据行

【分享成果,随喜正能量】129 爱出者爱返,福往者福来。怀揣一颗善良的心,本本分分,坦坦荡荡,多去帮助需要的人,坚持善良做人,才能不负于人,不负自己。。

第二十四讲 EXCEL中,如何删除重复数据行

各位好,今天开始讲VBA代码解决方案的二十四讲:在EXCEL中,如何借助于代码来完成删除重复行的工作。在实际的工作中这个工作是经常用到的,判断有没有重复的数据,是EXCEL数据统计中非常重要的工作的工作之一,也是经常处理的工作之一。如果掌握了这个技巧,无形中会提高自己的工作效率,而且还可以提高工作的准确性。

1 应用场景的具体分析及Countif函数

实例:在实际应用中,可能需要删除工作表中A列的重复内容而只保留一行,如何来解决这个问题呢?可以借助工作表CountIf函数来完成. 我们先来讲解一下Countif函数.

  • Countif函数: 是Microsoft Excel中对指定区域中符合指定条件的单元格计数的一个函数,在WPS,Excel2003和Excel2007等版本中均可使用。

语法规则如下:countif(range,criteria)

参数:

a) range 要计算其中非空单元格数目的区域

b) criteria 以数字、表达式或文本形式定义的条件

2 删除重复数据行的代码及代码解读

在讲解完这个函数后,我们来看代码:

Sub mynz_24() '第24讲 EXCEL中,如何删除重复数据行

Dim r As Integer

Dim i As Integer

With Sheets("24")

r = .[A65536].End(xlUp).Row

For i = r To 1 Step -1

If WorksheetFunction.CountIf(.Columns(1), .Cells(i, 1)) > 1 Then

.Rows(i).Delete

End If

Next

End With

End Sub

代码截图:

代码解析:mynz_24过程删除工作表A列重复单元格所在的整行内容,只保留一行。

1) 第5行代码取得工作表中A列的最后一个非空单元格的行号,要注意Range对象的End属性。不知读者是否已经掌握。

2) 第6行到第10行代码从最大行数至最小行数循环判断A列单元格内容是否重复并删除重复单元格所在的整行。和上一讲一样,此处For...Next循环也要从最大行数至最小行数开始循环判断,否则可能会删除不净。

3) 其中第7、8行代码使用工作表CountIf函数判断单元格内容是否重复,如果重复则删除该单元格所在的行。

  • [A65536] 适用于低版本Excel,如果是高版本,可以替换为[A1048576],一般情况,即使是[A65536]也足矣,如有特殊情形,学员要注意更改,也可以用通用模式Rows.Count代替,学员要注意。

运行前mynz_24过程工作表区域下截图:

运行后的截图:

运行的结果后,可以看到和预想的一样。

今日内容回向:

1 删除工作表中重复数据的思路是什么?

2 COUNTIF 的意义是什么?

3 上面代码中.Columns(1)的意义是什么?

本讲内容参考程序文件:VBA代码解决方案(22-26).xlsm

我20多年的VBA实践经验,全部浓缩在下面的各个教程中:



相关文章:

  • 2025深圳杯东三省数学建模竞赛选题建议+初步分析
  • hadoop伪分布式模式
  • MySQL RR (Repeatable Read) 隔离级别规则细节
  • B/S架构:定义、原理及其在软件测试中的应用
  • 软考中级-软件设计师 数据结构(手写笔记)
  • 基于静态局部立方体贴图的高效软阴影
  • 【效率提升】Vibe Coding时代如何正确使用输入法:自定义短语实现Prompt快捷输入
  • UE 材质 条纹循环发光
  • 【Token系列】14|Prompt不是文本,是token结构工程
  • 2025年“深圳杯”数学建模挑战赛B题-LED显示屏颜色转换设计与校正
  • 构建网页版IPFS去中心化网盘
  • PostgreSQL 中 VACUUM FULL 对索引的影响
  • VMware Workstation 创建虚拟机并安装 Ubuntu 系统 的详细步骤指南
  • uniapp 实现时分秒 分别倒计时
  • 从零开始学Python游戏编程48-二维数组2
  • git did not exit cleanly (exit code 128) 已解决
  • 【uniapp】在UniApp中检测手机是否安装了某个应用
  • Canvas基础篇:图形绘制
  • 卫星变轨轨迹和推力模拟(单一引力源)MATLAB
  • AI驱动的决策智能系统(AIDP)和自然语言交互式分析
  • 建设银行南昌分行引金融“活水”,精准灌溉乡村沃土
  • 国际锐评:菲律宾“狐假虎威”把戏害的是谁?
  • 直播电商行业代表呼吁:携手并肩伸出援手助力外贸企业攻坚克难
  • 银川市长信箱被指“已读乱回”,官方通报:对相关责任人问责处理
  • 加拿大警方:已确认有9人在温哥华驾车撞人事件中遇难
  • 视频丨伊朗港口爆炸事件灭火工作已完成80%