Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
261 views
in Technique[技术] by (71.8m points)

excel - VBA macro delete cells containing #N/A and shift up the cells (not the rows)

I'm creating a ranking and I need to delete all the cells with #N/A (pasted as text, not formula) and to delete those cells and shhift them up.

The worksheet contains 503 raws and I need it from column A to T. enter image description here

Thanks in advance, I have tried so many VBA codes of this web and I'm not able to find something that works.

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

Try,

dim rng as range

with worksheets("sheet1")
    on error resume next
    set rng = .range("A:T").specialcells(xlcelltypeformulas, xlerrors)
    if not rng is nothing then
        rng.delete shift:=xlup
    end if
    set rng = .range("A:T").specialcells(xlcelltypeconstants, xlerrors)
    if not rng is nothing then
        rng.delete shift:=xlup
    end if        
    on error goto 0
end with

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...