Excel精英培训网

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

[已解决]一次性清除零值,寻求更好的方法?

[复制链接]
发表于 2012-7-20 14:17 | 显示全部楼层 |阅读模式
有没有好的办法,可以一次性清除零值。
附件中有一种方法,只是要是数据量很大的时候,运行起来就会很慢。各位有没有更好的方法?
相互学习一下。 Book31.rar (6.52 KB, 下载次数: 35)
excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2012-7-20 14:28 | 显示全部楼层
回复

使用道具 举报

发表于 2012-7-20 14:31 | 显示全部楼层
回复

使用道具 举报

发表于 2012-7-20 14:34 | 显示全部楼层
你的宏代码是否加一条更新为否比较好。
回复

使用道具 举报

发表于 2012-7-20 14:49 | 显示全部楼层
查找和替换是很方便的额
回复

使用道具 举报

 楼主| 发表于 2012-7-20 15:16 | 显示全部楼层
我知道查找替换最方便,但我想用VBA,因为数据是随时都在变化的。
还有Acitvewindow.displayzeros=false这只是把零值隐藏,而不是删除,达不到目的。
回复

使用道具 举报

发表于 2012-7-20 15:30 | 显示全部楼层    本楼为最佳答案   
本帖最后由 suye1010 于 2012-7-20 15:36 编辑
  1. Cells.Replace What:="1", Replacement:="", LookAt:=xlWhole, SearchOrder _
  2.         :=xlByRows, MatcshCae:=False, SearchFormat:=False, ReplaceFormat:=False
复制代码
回复

使用道具 举报

发表于 2012-7-20 15:36 | 显示全部楼层
Call Cells.Replace(0, "", xlWhole)
回复

使用道具 举报

发表于 2012-7-20 16:26 | 显示全部楼层
本帖最后由 scsys1 于 2012-7-20 16:30 编辑
  1. Sub 清除零值()
  2. Application.ScreenUpdating = False
  3. For Each cel In ActiveSheet.UsedRange
  4. If cel = 0 Then cel.ClearContents
  5. Next
  6. Application.ScreenUpdating = True
  7. End Sub
复制代码
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-5 01:36 , Processed in 0.277497 second(s), 13 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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