Excel精英培训网

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

[已解决][求助]这个程序怎么编

[复制链接]
发表于 2008-12-26 15:15 | 显示全部楼层 |阅读模式

A1-A1000中有很多数据,我想用VBA程序实现如下功能:

1.如果A列中某格为空,则该行整行删除    例如:假设A5为空,则第5行整行删除

2.从上往下,如果A列中某格数据与上面的某一格一样,则该行整行删除  例如:假设A5中数据与A2相同,则第5行整行删除

 

谢谢

 

最佳答案
2008-12-30 12:28

SlEa5lrQ.rar (6.49 KB, 下载次数: 11)

发表于 2008-12-26 15:42 | 显示全部楼层

Sub yy()
Dim d As Object, c As Range
Set d = CreateObject("Scripting.Dictionary")
For Each c In Range([a1], [a65536].End(3))
If Not d.exists(c.Value) Then
d(c.Value) = ""
Else
c = ""
End If
Next
[a:a].SpecialCells(4).Delete (3)
End Sub
回复

使用道具 举报

 楼主| 发表于 2008-12-30 11:53 | 显示全部楼层
回复

使用道具 举报

发表于 2008-12-30 12:17 | 显示全部楼层

QUOTE:
以下是引用一字头螺丝在2008-12-26 15:15:00的发言:

A1-A1000中有很多数据,我想用VBA程序实现如下功能:

1.如果A列中某格为空,则该行整行删除    例如:假设A5为空,则第5行整行删除

2.从上往下,如果A列中某格数据与上面的某一格一样,则该行整行删除  例如:假设A5中数据与A2相同,则第5行整行删除

 

谢谢

 

将顺序颠倒过来,从后面向前面删除就可以了。

回复

使用道具 举报

发表于 2008-12-30 12:28 | 显示全部楼层    本楼为最佳答案   

SlEa5lrQ.rar (6.49 KB, 下载次数: 11)

LdMzvqZs.rar

6.49 KB, 下载次数: 0

[求助]这个程序怎么编

回复

使用道具 举报

 楼主| 发表于 2008-12-30 12:44 | 显示全部楼层

请问

[a:a].SpecialCells(4).Delete (3)
中的Delete()里的3是什么意思

回复

使用道具 举报

发表于 2008-12-30 12:48 | 显示全部楼层

试试 我这个

[em01]
回复

使用道具 举报

发表于 2008-12-30 12:51 | 显示全部楼层

楼上那个的方法是 重复时变成空 然后定位空值 整行删除

回复

使用道具 举报

 楼主| 发表于 2008-12-30 13:02 | 显示全部楼层

我用二楼的程序试了下,程序拆分成两个能实现各自的功能,但是组合起来却无法得到最后的结果,请帮我看一下,谢谢

回复

使用道具 举报

 楼主| 发表于 2008-12-30 13:03 | 显示全部楼层

[em01]
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-14 20:00 , Processed in 0.373620 second(s), 6 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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