码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Excel 2021|VBA不可不说的注意事项(第一篇)|VBA精准控制选择范围、VBA提高运行速度并降低运行时的内存消耗


      最近总是遇到只有Excel表、没有数据库的情况,不太可能让别人搭Python环境来建数据库,但对常用数据库的使用也不太熟悉,也没买服务器不能让别人远程操控。再加上Python操作Excel的效率令人发指,不妨退而求其次直接学会VBA。

      没想到坑挺多的,来分享一下其中的典型。考虑到之后可能还需要使用它,可能还会遇到其他天坑,因此,不妨将本文提到的作为VBA不可不说的注意事项(第一篇)。

    文章目录

    • 1 要想运行之后Excel文件的大小不爆炸,你需要……
      • 慎用Cells.xxx、Range(A:A)等选择范围极其广的,精确选择范围
    • 2 要想运行时内存不爆炸,你需要……
      • 禁用应用程序屏幕更新、禁用事件

    1 要想运行之后Excel文件的大小不爆炸,你需要……

    慎用Cells.xxx、Range(A:A)等选择范围极其广的,精确选择范围

    (1)引言

    举个例子,原始表格如下图所示,10KB:

    在这里插入图片描述

    我添加一个筛选器,设置成绩>19,结果如下,Excel文件大小不变:

    在这里插入图片描述

    接下来,我全选(也就是Cells的选择范围),将这个筛选结果复制到另一个Sheet工作表中,并保存:

    在这里插入图片描述

    您猜怎么着?
    ——文件大小直接爆炸啦!

    在这里插入图片描述

    并且更糟糕的是,此时再删除新表,文件大小也不会完美复原了。

    在这里插入图片描述
    不过好消息是,Ctrl+Z撤回操作可以将大小完美复原。
    但谁编程的时候会没事用Ctrl+Z啊?

    (2)解决方式

    最关键的是,确定范围的代码:

    参考:

    1. Excel VBA获取最后一行列_CSDN
    2. Excel VBA-查找包含数据的最后一列_JavaRoad问答社区

    对于行,确定最后一行的行号的方式是:

    LastRow = Range("A" & Rows.Count).End(xlUp).Row
    - LastRow = UsedRange.Rows.Count 
    Range("A1:N" & LastRow).Select
    
    • 1
    • 2
    • 3

    第一行,令 LastRow = 第A列的行数;(如果不只是需要A列的行数,而是需要所有用过的行,就用UsedRange.Rows.Count)
    第二行,精确选择所需要的范围,A1到N[LastRow]。

    Rows.Count是当前版本最大的行号,2007年之前的版本最大行号是65535,而之后的版本增大了最大行数,变成1048576。这种方式获取的最后一行只会包括内容不为空的行,而UsedRange.Rows.Count找到的行,会包括仅设置了格式的行,因此建议用第一种。

    对于列,确定最后一列的列号的方式是:

    LastColumn = Cells(1, Columns.Count).End(xlToLeft).Column
    Range(Cells(1,1), Cells(1, LastColumn)).Select
    
    • 1
    • 2

    第一行,令 LastColumn = 第1行的列数;(如果不只是需要第一行的列数,而是需要所有用过的列,就用UsedRange.Columns.Count)
    第二行,精确选择所需要的范围,第一行第一个,到第一行最后一个。

    另一种方法:Cells.Find(What:="*", After:=ws.Cells(1, 1), LookIn:=xlFormulas, LookAt:= _ xlPart, SearchOrder:=xlByColumns, SearchDirection:=xlPrevious, MatchCase:=False)。我还没试过,来源于参考的第二篇内容。

    倘若不确定最后一行/列的位置,直接Cells.Select,就容易出现选了非常非常多没用的东西的情况。

    2 要想运行时内存不爆炸,你需要……

    禁用应用程序屏幕更新、禁用事件

    在每个编写的宏的最开始加上这三行:

    ActiveWorkbook.Save
    Application.ScreenUpdating = False
    Application.EnableEvents = False
    
    • 1
    • 2
    • 3

    结尾加上这三行:

    ActiveWorkbook.Save
    Application.ScreenUpdating = True
    Application.EnableEvents = True
    
    • 1
    • 2
    • 3

    这些代码禁用应用程序屏幕更新、禁用事件。这保证你的宏在运行时,屏幕不会闪来闪去的,Excel运存不会爆炸,同时较好地提高运行速度(亲测提高一倍左右)。等运行完了,屏幕才会统一发生变化。

    参考:Excel,VBA:清除内存-码农家园-StackFlow译文,该文还提出使用Evaluate直接计算值,而不是将公式放入表中,会加速。

  • 相关阅读:
    系分 - 项目管理
    vue项目打包后使用reverse-sourcemap反编译到源码(详解版)
    vue内嵌iframe跨域通信
    存储 MD5 的值应该用 VARCHAR 还是 CHAR
    tio-websocket-spring-boot-starter的最简单实例,看完你一定有所收获
    如果有些字段不想进行序列化怎么办?
    作为前端开发,你应该知道的这十几个在线免费工具
    7.基于SpringBoot3+Security6+JWT实现鉴权机制(一)
    java:application.properties的详细使用以及区分环境
    聚乳酸改性乳清白蛋白/肌白蛋白/豆清白蛋白/蓖麻蛋白/豌豆白蛋白1b ( PA1b)|蛋白偶联修饰
  • 原文地址:https://blog.csdn.net/qq_46106285/article/details/127400854
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号