VBA常见的知识都有哪些,让AI编写的VBA经常 报错,所以VBA的基础还是要学习的

news2025/3/20 6:05:27

掌握这些能够大大的提高VBA的编写效率,欢迎来到涛涛聊AI。

1. 异常处理

'Cleanup:'是VBScript的错误处理标签,用于标记程序执行失败或退出时需要执行的清理操作(如关闭文件、释放对象)。这段代码会在遇到错误或用户取消操作时跳转到这里执行资源回收,确保程序安全退出。

2.创建对象 CreateObject

在VBScript中,CreateObject("Scripting.Dictionary")用于创建字典对象,这是Windows脚本宿主提供的键值对存储结构。字典对象允许通过唯一键快速查找、添加或删除关联值,常用于需要高效数据管理的场景,比如存储配置信息或处理Excel数据时的条件匹配。

3. 输出调试

在VBScript(VBS)中使用 cscript 运行脚本时,可以通过 WScript.EchoMsgBox 来打印输出信息。以下是具体的使用方法:

        1)使用 WScript.Echo

WScript.Echo 是专门用于在命令行中打印输出的方法。它会在控制台窗口中显示消息,适合在 cscript 环境下使用。

示例代码:

WScript.Echo "Hello, World!

运行方式:

cmd  cscript yourscript.vbs

        2)使用 MsgBox

MsgBox 会弹出一个对话框显示消息,适合在需要用户交互的场景中使用。

示例代码:

MsgBox "Hello, World!"

运行方式:

 cmd  cscript yourscript.vbs

输出结果: 会弹出一个对话框,显示 "Hello, World!"。

  1. 区别与选择

  • WScript.Echo:适合在命令行中输出信息,不会中断脚本的执行。

  • MsgBox:适合需要用户确认或交互的场景,但会中断脚本的执行,直到用户关闭对话框。

  1. 其他注意事项

  • 如果你希望脚本在 cscriptwscript 环境下都能正常运行,可以使用 WScript.Echo 并检查脚本的运行环境。

  • 如果需要将输出重定向到文件,可以使用 >>> 操作符,例如:

4. 字典的使用

' 创建一个字典对象
Set dict = CreateObject("Scripting.Dictionary")

' 向字典中添加键值对
dict.Add "Apple", 5
dict.Add "Banana", 3
dict.Add "Orange", 8

' 检查某个键是否存在
If dict.Exists("Banana") Then
    MsgBox "Banana exists in the dictionary!"
Else
    MsgBox "Banana does not exist in the dictionary."
End If

' 遍历字典中的所有键值对
For Each key In dict.Keys
    MsgBox "Key: " & key & ", Value: " & dict(key)
Next

CreateObject("Scripting.Dictionary") 是 VBScript 中用于创建一个字典对象的方法。字典对象是一种键值对(Key-Value Pair)集合,类似于其他编程语言中的哈希表或映射。字典对象允许你通过唯一的键来存储和检索值,键和值可以是任何类型的数据。

字典对象的常用方法:

  • Add(key, value):向字典中添加一个键值对。
  • Item(key):获取或设置指定键的值。
  • Exists(key):检查字典中是否存在指定的键。
  • Remove(key):从字典中移除指定的键值对。
  • RemoveAll():清空字典中的所有键值对。
  • Keys():返回字典中所有键的数组。
  • Items():返回字典中所有值的数组。
  • Count:返回字典中键值对的数量。

示例 1:创建一个字典并添加键值对

' 创建一个字典对象
Set dict = CreateObject("Scripting.Dictionary")

' 向字典中添加键值对
dict.Add "Name", "John"
dict.Add "Age", 30
dict.Add "City", "New York"

' 输出字典中的值
MsgBox "Name: " & dict("Name") & vbCrLf & _
       "Age: " & dict("Age") & vbCrLf & _
       "City: " & dict("City")

示例 2:检查键是否存在并遍历字典

' 创建一个字典对象
Set dict = CreateObject("Scripting.Dictionary")

' 向字典中添加键值对
dict.Add "Apple", 5
dict.Add "Banana", 3
dict.Add "Orange", 8

' 检查某个键是否存在
If dict.Exists("Banana") Then
    MsgBox "Banana exists in the dictionary!"
Else
    MsgBox "Banana does not exist in the dictionary."
End If

' 遍历字典中的所有键值对
For Each key In dict.Keys
    MsgBox "Key: " & key & ", Value: " & dict(key)
Next

5. 数据类型

在 VBA(Visual Basic for Applications)中,数据类型用于定义变量或常量可以存储的数据种类。以下是 VBA 中常见的数据类型及其说明:


1. 数值类型

数据类型

描述

存储空间

范围或示例

Byte

无符号整数

1 字节

0 到 255

Integer

有符号整数

2 字节

-32,768 到 32,767

Long

有符号长整数

4 字节

-2,147,483,648 到 2,147,483,647

Single

单精度浮点数

4 字节

-3.402823E38 到 3.402823E38

Double

双精度浮点数

8 字节

-1.79769313486232E308 到 1.79769313486232E308

Currency

用于货币计算的定点数

8 字节

-922,337,203,685,477.5808 到 922,337,203,685,477.5807


2. 文本类型

数据类型

描述

存储空间

范围或示例

String

文本字符串

1 字节/字符

定长字符串:最多 65,400 字符
变长字符串:最多 2^31 字符

String * n

定长字符串(n 为长度)

n 字节

例如:Dim s As String * 10


3. 日期/时间类型

数据类型

描述

存储空间

范围或示例

Date

日期和时间

8 字节

100 年 1 月 1 日 到 9999 年 12 月 31 日


4. 布尔类型

数据类型

描述

存储空间

范围或示例

Boolean

布尔值(真或假)

2 字节

TrueFalse


5. 对象类型

数据类型

描述

存储空间

范围或示例

Object

对象引用

4 字节

例如:Set ws = ThisWorkbook.Sheets(1)

Variant

可变类型,可以存储任何类型的数据

根据数据

默认类型,灵活性高,但效率较低


6. 特殊类型

数据类型

描述

存储空间

范围或示例

Variant

可变类型,可以存储任何类型的数据

根据数据

默认类型,灵活性高,但效率较低

Empty

未初始化的变量

0 字节

例如:Dim x As Variant

Null

表示无效数据

0 字节

例如:x = Null

Error

错误代码

2 字节

例如:Err.Number


7. 用户定义类型

数据类型

描述

存储空间

范围或示例

Type

用户自定义类型(结构体)

根据成员

例如:
Type Person
Name As String
Age As Integer
End Type


示例代码

Sub DataTypesExample()
    ' 数值类型
    Dim num1 As Integer
    num1 = 100

    Dim num2 As Double
    num2 = 3.14159

    ' 文本类型
    Dim text As String
    text = "Hello, VBA!"

    ' 日期/时间类型
    Dim dt As Date
    dt = #12/31/2023#

    ' 布尔类型
    Dim flag As Boolean
    flag = True

    ' 对象类型
    Dim ws As Worksheet
    Set ws = ThisWorkbook.Sheets(1)

    ' 用户定义类型
    Type Person
        Name As String
        Age As Integer
    End Type

    Dim p As Person
    p.Name = "John"
    p.Age = 30

    ' 输出
    MsgBox "Integer: " & num1 & vbCrLf & _
           "Double: " & num2 & vbCrLf & _
           "String: " & text & vbCrLf & _
           "Date: " & dt & vbCrLf & _
           "Boolean: " & flag & vbCrLf & _
           "Person: " & p.Name & ", " & p.Age
End Sub

注意

代码位置

  • Dim 语句必须放在过程(如 Sub 或 Function)或模块的声明部分。
  • 如果 Dim 语句放在模块的顶部,但未在 Sub 或 Function 中,可能会导致错误。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2318192.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

DeepSeek(8):结合Kimi-PPT助手一键生成演示报告

1 生成内容 在Deepseek中生成内容: 帮我创建年度计划,描述《智能枕头》产品的如何在全国销售,计划切分到每个月。从而让我们的老板和团队对报告充满信息。输出的内容我需要放到ppt中进行展示。 使用Deepseek R1模型,如下&#x…

【MySQL】MySQL如何存储元数据?

目录 1.数据字典的作用 2. MySQL 8.0 之前的数据字典 3. MySQL 8.0 及之后的数据字典 4.MySQL 8 中的事务数据字典的特征 5.数据字典的序列化 6. .sdi文件的作用: 7..sdi的存储方式 在 MySQL 中,元数据(Metadata) 是描述数…

用ASCII字符转化图片

代码 from PIL import Image# 定义 ASCII 字符集,从最暗到最亮 ASCII_CHARS "%#*-:. "def resize_image(image, new_width100):width, height image.sizeratio height / widthnew_height int(new_width * ratio)resized_image image.resize((new_wi…

蓝桥与力扣刷题(蓝桥 组队)

题目:作为篮球队教练,你需要从以下名单中选出 1 号位至 5 号位各一名球员,组成球队的首发阵容。 每位球员担任 1号位至 5号位时的评分如下表所示。请你计算首发阵容 1 号位至 5 号位的评分之和最大可能是多少? 本题为填空题&…

AI Agent系列(六) -基于ReAct架构搭建LLM Agent(Deepseek)

AI Agent系列【六】 一、 ReAct1.1 ReAct 的处理过程:1.1 代码结构 二、 Python代码实现2.1 通过Zero-shot 实现python代码实例Python代码示例1:python代码实现示例2 一、 ReAct ReAct 是 Reseaning 和 Action 两个词的前缀合成,代表着先推…

AnyTouch:跨多个视觉触觉传感器学习统一的静态动态表征

25年3月来自人大、武汉科技大学和北邮的论文“AnyTouch: Learning Unified Static-dynamic Representation Across Multiple Visuo-tactile Sensors”。 视觉触觉传感器旨在模拟人类的触觉感知,使机器人能够精确地理解和操纵物体。随着时间的推移,许多精…

YOLOv11 目标检测

本文章不再赘述anaconda的下载以及虚拟环境的配置,博主使用的python版本为3.8 1.获取YOLOv11的源工程文件 链接:GitHub - ultralytics/ultralytics: Ultralytics YOLO11 🚀 直接下载解压 2.需要自己准备的文件 文件结构如下:红…

VSCode C/C++ 环境搭建指南

一、前言 Visual Studio Code(简称 VSCode)是一款轻量级且功能强大的跨平台代码编辑器,凭借丰富的插件生态和高度的可定制性,深受开发者喜爱。对于 C/C 开发者而言,在 VSCode 中搭建开发环境,能够获得灵活…

Python 中下划线 “_” 的多面性:从变量到约定

# Python中下划线“_”的多面性:从变量到约定 在Python的语法体系里,下划线“_”看似毫不起眼,实则扮演着极为重要且多样化的角色。它不仅能作为普通变量参与编程,更在多个特殊场景下有着独特的用途与约定。深入理解下划线的各种…

Vue3项目开发:状态管理实践指南

# Vue3项目开发:状态管理实践指南 一、引言 背景介绍 在Vue项目中,状态管理是一个非常重要的话题。合理的状态管理能够帮助我们更好地组织和管理数据,提升项目的可维护性和可扩展性。本文将深入探讨Vue3项目中状态管理的最佳实践,…

数据结构-------栈

顺序栈: 一、数据结构定义 数据元素 DATATYPE typedef struct person {char name[32];char sex;int age;int score; } DATATYPE;顺序栈结构 SeqStack typedef struct list {DATATYPE *head; // 栈空间首地址int tlen; // 栈总容量(total leng…

机器学习概要

文章目录 一、什么是机器学习 二、机器学习的种类 1. 有监督学习 2. 无监督学习 3.强化学习 三、机器学习的应用 四、机器学习的步骤 1. 数据的重要性 2. 数据和学习的种类 3. 可视化 一、什么是机器学习 机器学习指的是计算机根据给定的问题、课题或环境进行学习&a…

【LangChain入门 2 Model组件】开始!LLM Models简单对话

文章目录 一、使用langchain_ollama二、采用DeepSeek的API三、Model 介绍3.1 OllamaLLM 预训练模型3.2 ChatOllama 聊天预训练模型3.3 OllamaEmbeddings 实现一个helloworld,跑通一个简单的对话。 后面章节会正式介绍LangChain的各个功能。 后台llm的端口可以任意选…

C++20 中线程管理与取消机制的深度剖析

文章目录 std::jthread:更智能的线程管理背景与优势构造函数与 std::stop_token 的集成 std::stop_token、std::stop_source 和 std::stop_callback:灵活的取消机制std::stop_token:取消请求的指示器std::stop_source:取消请求的发…

Vue3 核心特性解析:Suspense 与 Teleport 原理深度剖析

Vue3 核心特性解析:Suspense 与 Teleport 原理深度剖析 一、Teleport:突破组件层级的时空传送 1.1 实现原理图解 #mermaid-svg-75dTmiektg1XNS13 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-s…

FPGA——实现LED流水灯

文章目录 一、Quartusll_18.1和VS Code软件的关联二、DE2-115的时钟电路三、流水灯的分层次设计四、总结 一、Quartusll_18.1和VS Code软件的关联 1.先打开Quartus II 软件,然后选择菜单栏“Tools”下的“Options…”。 2.点击“Options…”,在弹出的对…

Excel 小黑第12套

对应大猫13 涉及金额修改 -数字组 -修改会计专用 VLOOKUP函数使用(查找目标,查找范围(F4 绝对引用),返回值的所在列数,精确查找或模糊查找)双击填充柄就会显示所有值 这个逗号要中文的不能英…

滚动元素的新api

点击的时候需要双重视图滚动 itemClick(id) {// 滚动到对应位置this.$nextTick(() > {// 找到对应 id 在 initList2 中的索引const index this.initList2.findIndex((item) > item.id Number(id));if (index ! -1) {// 获取所有菜单项const menuItems document.queryS…

多机调度问题(C语言)

代码如下&#xff1a; #include<stdio.h> #include<stdlib.h>int compare(void* a, void* b)//比较函数&#xff0c;用于qsort按处理时间从大到小排序 {return *(int*)a - *(int*)b; }int LPT(int jobs[], int n, int m)//多机调度问题的LPT算法 {qsort(jobs, n, …

烽火HG680-KB_海思HI3798MV310_安卓9.0_U盘强刷固件包及注意点说明

之前发布过这个固件包&#xff0c;关于烽火HG680-KA&#xff0f;HG680-KB_海思HI3798MV310_安卓9.0_U盘强刷固件包详细说明一下&#xff0c;汇总总结一些常遇到的情况&#xff0c;这次固件会分开发布&#xff0c;以免混淆。 上一个帖子地址&#xff1a;烽火HG680-KA&#xff0…