ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 805|回复: 0

求老师看看,能不能加些释放内存的代码或者简化一下程序?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2017-11-12 14:06 | 显示全部楼层 |阅读模式
本帖最后由 lhj1861 于 2017-11-12 14:07 编辑

求老师帮忙看看,程序没问题实现的功能很简单,就是把B列非空的行在A列都付给公式,我的数据有700多条,以后人员会一直增加,因为加了这张表其他表的运行都受影响了,不知道怎么优化代码,或者释放内存什么的?
Sub 处理()

Dim a1 As Integer, r As Integer, i As Integer, m As String
r = 1
   Application.ScreenUpdating = False
    Worksheets("花名册").Activate
   With Sheets("花名册")
         a1 = .Range("B65536").End(xlUp).Row
'------------------------以下代码实现把B列有内容的行在A列都复制公式
    .Range("A2").Select
    ActiveCell.FormulaR1C1 = _
        "=IF(ISERROR(VLOOKUP(INDIRECT(""$B$2:$B$1000""),INDIRECT(""人员信息!$C$3:$D$200""),2,FALSE)),"""",VLOOKUP(INDIRECT(""$B$2:$B$1000""),INDIRECT(""人员信息!$C$3:$D$200""),2,FALSE))"
    Selection.AutoFill Destination:=.Range("A2", "A" & a1), Type:=xlFillCopy
    .Range("A2", "A" & a1).Select
'------------------------以下代码实现把A列升序排列'
    .Columns("A:A").Select
    .Range("A1", "J" & a1).Sort Key1:=.Range("A1"), Order1:=xlAscending, Header:= _
    xlGuess, OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom, _
    SortMethod:=xlPinYin, DataOption1:=xlSortNormal
'------------------------以下代码实现把A列第2行开始公式值为空的行删除  Formula
    Application.ScreenUpdating = False
        For i = 2 To a1
            m = .Range("a" & i)
             If m = "" Then
                '.Rows(r).Delete
                r = r + 1
             Else
                Exit For
             End If
        Next i
         .Rows("2" & ":" & r).Select
         Selection.Delete Shift:=xlUp
    End With
    Application.ScreenUpdating = True

End Sub
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2025-1-12 12:00 , Processed in 0.017358 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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