7、[VBA入门到放弃笔记]如何快速获得信息?

如何快速获取想要的却不知道的信息?这是十分重要的技能!!!

  • 以一个例子字来介绍:怎样删除行,其代码是什么?

  • 方法1:录制宏

Sub 宏1()'操作了删除第4行,第7行,第10行。
'
' 宏1 宏
'

'
    Rows("4:4").Select
    Selection.Delete Shift:=xlUp
    Rows("7:7").Select
    Selection.Delete Shift:=xlUp
    Rows("10:10").Select
    Selection.Delete Shift:=xlUp
End Sub
  • 从上面获取到的关键词就是Rows,对代码作点修改。看此句能否运行。
rows("4:4").delete Shift:=xlUp
gfgfg.gif
  • 代码能够运行,代码能用,然后我们就获取了删除行这个操作的代码。

  • 方法2:百度。
  • 浏览了一些信息后,发觉这样的代码也许也能删除行,利用的是单元格的EntireRow属性。按照字面意思就是,单元格所在的整行删除。同样测试代码。
单元格.EntireRow.Delete
  • 敲入代码就有提示了。


  • 代码同样能够执行.
hgh.gif

  • 光说不练假把式,做个小练习。删除要删除的行,随便一个方法。
删除要删除的行
Sub 宏1()
    Dim i As Integer
    For i = 1 To 11
        If Cells(i, 1) = "要删除的行" Then
            Rows("i:i").Delete Shift:=xlUp
        End If
    Next
End Sub
  • 代码报错,调试标明Rows处出错了?如何解决?
Paste_Image.png
  • 细心一想,i是变量 i:i的写法是不对的。不能因为测试的时候代码是rows("4:4"),我们就惯性写成Rows("i:i")。应该是下面的写法
Sub 宏1()
    Dim i As Integer
    For i = 1 To 11
        If Cells(i, 1) = "要删除的行" Then
            Rows(i & ":" & i).Delete Shift:=xlUp
        End If
    Next
End Sub
  • 但结果仍然不对,不能删除干净?这又是为神马?
  • 注意看操作,删除第4行后,第5行就上移到第4行了。这就是出错的原因,请再想想。看代码里的:Shift:=xlUp(向上移动)
  • 所以删除行要删除干净,就得要从下面开始循环.
Sub 宏1()
    Dim i As Integer
    For i = 11 To 1 Step -1    '*********LOOK 
        If Cells(i, 1) = "要删除的行" Then
            Rows(i & ":" & i).Delete Shift:=xlUp
        End If
    Next
End Sub
ghhhhhhhh.gif
  • 实际 Rows(i & ":" & i)可以写成 Rows(i),同样能删除代码。关键的是删除行要从下面向上循环删除。
Sub 宏1()
    Dim i As Integer
    For i = 11 To 1 Step -1
        If Cells(i, 1) = "要删除的行" Then
            Rows(i).Delete Shift:=xlUp
        End If
    Next
End Sub

附上Rows属性文档说明

Excel VBA教程:Rows属性
对于 Application对象,返回代表活动工作表所有行的Range对象。如果活动文档不是工作表,Rows属性无效。对于 Range对象,返回代表指定区域所有行的 Range对象。 对于 Worksheet对象,返回代表指定工作表所有行的 Range对象。Range对象,只读。
说明
有关返回集合中单个成员的详细信息,请参阅返回集合中的对象
在不用对象识别符的情况下使用此属性等价于ActiveSheet.Rows

当应用于含多个选定区域的 Range对象时,该属性只返回该区域中第一个子区域内的行。例如,如果 Range对象有两个子区域:A1:B2 和 C3:D4,则Selection.Rows.Count
返回 2 而不是 4。若要在一个可能包含多个选定区域的区域中使用该属性,请测试Areas.Count
来判断该区域是否包含多个选择区域。如果是,则像第 3 个示例中所示,在该区域中的每个子区域上循环。
Excel VBA教程:Rows属性·示例
本示例删除 Sheet1 的第三行。

Worksheets("Sheet1").Rows(3).Delete

本示例检查第一张工作表上当前区域中的行,如果某行的第一个单元格值与前一行的第一个单元格的值相等,则删除此行。

For Each rw In Worksheets(1).Cells(1, 1).CurrentRegion.Rows   
          this = rw.Cells(1, 1).Value    
          If this = last Then rw.Delete    
          last = this
Next

本示例显示 Sheet1 选定区域中的行数。如果选择了多个子区域,本示例将对每一个子区域进行循环。

Worksheets("Sheet1").Activate
areaCount = Selection.Areas.Count
If areaCount <= 1 Then
    MsgBox "The selection contains " & _
        Selection.Rows.Count & " rows."
Else
    i = 1
    For Each a In Selection.Areas
        MsgBox "Area " & i & " of the selection contains " & _
            a.Rows.Count & " rows."
        i = i + 1
    Next a
End If
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容

  • 本例为设置密码窗口 (1) If Application.InputBox(“请输入密码:”) = 1234 Th...
    浮浮尘尘阅读 13,594评论 1 20
  • 1.1 VBA是什么 直到90年代早期,使应用程序自动化还是充满挑战性的领域.对每个需要自动化的应用程序,人们不得...
    浮浮尘尘阅读 21,707评论 6 49
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,577评论 18 399
  • 看看下面的Excel界面截图,“排序”和“筛选”往往在一起,这大概是很多数据需要先排序后筛选吧! 在Excel 2...
    完美Excel阅读 28,555评论 1 5
  • 独爱岁月静好时,遂愿此生不相思
    秋一叶西阅读 227评论 0 0