VBA-Excel
VBA
一、数据类型与变量
-
常用数据类型:
- Byte:字节型,0~255。
- Integer:整数型,用于存储整数值,范围 -32768 到 32767。
- Long:长整型,可存储更大范围的整数,范围 -2147483648 到 2147483647。
- Double:双精度浮点数,用于表示带有小数的数值,精度较高。
- String:字符串型,存储文本信息,用双引号括起来,如 “Hello World”。
- Boolean:布尔型,只有 True 和 False 两个值,常用于条件判断。
- Variant: 任意类型

-
变量声明:
- 使用
Dim关键字,如Dim num As Integer,声明一个名为 num 的整数型变量。也可以在一行声明多个变量,如Dim a As String, b As Double。
- 使用
二、控制语句与运算符
- 运算符与Java类似,只有几个特殊的
算数运算符
2^3 2的3次方' 求商整数
5\2 = 2'相除取余Mod
12 Mod 9 = 3比较运算符
'比较两个对象是否相同
对象1 Is 对象2 'Like 比较两个字符串是否匹配
' 通配符
* 任意多个字符
? 任意单个字符
# 任意单个数组[charlist] 位于charlist的任意一个字符
[!charlist]文本运算符
+ 拼接字符串
& 合并字符串逻辑运算符
And Or Not Xor 异或
Eqv 等价
Imp 蕴含
执行顺序
算数 比较 逻辑
- If 语句
If 条件 Then如果是
Else否则
End If ` 结束
- For循环
For i = start To end` 循环部分
Next i
- Select Case
Select Case 值 Case is 条件1Case is 条件2...Case Else ` 以上没有匹配End Select
- 遍历集合
For Each 变量 in 集合名称Next 变量
- DoWhile循环
Do While 循环条件' 跳出循环
exit doLoop
DoLoop While 循环条件
三、子程序和函数
- 子程序(Sub)
定义与作用:子程序是一段完成特定任务的代码块,不返回值。通常用于执行一系列操作。
Sub 子程序名称([参数列表])End Sub
- 函数(Function)
定义与作用:函数用于执行特定计算并返回一个值。可以在公式、条件判断等地方调用函数。
Function 函数名称([参数列表]) As 返回值类型函数名称 = 返回值
End Function
- 内置函数
| 函数名称 | 功能描述 |
|---|---|
| IsNumeric | 判断参数中数据是否为数字 |
| IsDate | 判断参数中数据是否为日期 |
| IsEmpty | 判断参数中数据是否为 Empty(空) |
| IsArray | 判断参数是否为数组 |
| IsError | 判断参数是否为错误值 |
| IsNull | 判断参数是否不包含任何有效数据 |
| IsObject | 判断参数是否为一个对象 |
| Int | 返回小于或等于参数的第一个整数 |
| Fix | 返回参数的整数部分 |
| Round | 返回四舍五入的值 |
| Sqr | 返回数值的平方根 |
| Abs | 返回数值的绝对值 |
| Rnd | 生成 0 - 1 之间的随机数 |
- 文本函数
| 函数名称 | 功能描述 |
|---|---|
Len | 求参数中数据包含的字符个数 |
Left、Right、Mid | 分别用于截取最左侧、最右侧、从任意位置开始的指定数量的字符 |
Ltrim、Rtrim、Trim | 分别用于去掉最左端、最右端、左右两端多余的空格 |
Ucase、Lcase | 分别将英文字母转换为大写、小写 |
InStr | 查找指定字符串在另一个字符串中的位置 |
Replace | 将字符串中某个位置的部分字符串替换为新字符 |
Format | 对参数指定的数据进行格式化 |
- 时间日期函数
| 函数名称 | 功能描述 |
|---|---|
Now、Date、Time | 返回执行该函数时计算机的系统日期、时间数据 |
Timer | 返回从凌晨 0 时到执行该函数时经过的秒数 |
DateSerial | 返回参数指定年、月、日组成的日期数据 |
Year、Month、Day | 返回参数指定日期中的年、月、日信息 |
TimeSerial | 返回参数指定时、分、秒组成的时间数据 |
Hour、Minute、Second | 返回参数指定时间中的时、分、秒信息 |
Format | 将具有日期数据外观的字符串转为日期数据 |
DateValue | 将具有时间数据外观的字符串转为时间数据 |
DateDiff | 求两个日期的间隔 |
- 数据转换函数
| 函数名称 | 功能描述 |
|---|---|
Val | 将参数指定的数据转为数值类型 |
CLng | |
CInt | |
CByte | |
CDbl | 将参数指定的数据转为双精度浮点型 |
CStr | 将参数指定的数据转为字符串型 |
CDate | 将参数指定的数据转为日期型 |
CBool | 将参数指定的数据转为布尔型 |
CVar | 将参数指定的数据转为 Variant 型 |
四、Excel 对象模型操作
- 工作簿(Workbook)
- 工作表(Worksheet)
- 新建一个工作表
workshets.add
- 获取表的名称
Sheets.Name
- 获取表的数量
Sheets.Count
- 单元格(Range)
- 单元格赋值
Range(“A1”).Value = “值”
连续选择的
“A1:B10” A1 -> B10 连续
不连续选择
“A1,B10” A1 和 B10
- 根据行号列号引用单个单元格
sells(行,列)
' 行必须为数字,列可以是数字也可以是A
- 选择行
rows(行号).select' 也可以连续使用
rows(3:10).rows(1) `表示第3到10的第一行
- 列
columns
- 选择单元格的相对单元格
offset
Range("A1").Offset(5,0) `表示从A1开始向下移动5,向右移动1
' 负数表示反向
- 获得行或列的最后单元格
End(xlUp)
`可选值:xlToLeft、xlToRight、xlUp、xlDown
- 单元格格式
将单元格区域存储到变量中
Set
例如:set title = range("B2;G2")合并单元格
title.Merge水平居中
HorizontalAlignment = xlCenter字体大小
Font.Size = 12字体颜色
Font.ColorIndex = 1字体加粗
Font.Bold = true单元格内部
Range.Interior单元格背景颜色
Interior.ColorIndex边框
Borders.LineStyle = true

相关文章:
VBA-Excel
VBA 一、数据类型与变量 常用数据类型: Byte:字节型,0~255。Integer:整数型,用于存储整数值,范围 -32768 到 32767。Long:长整型,可存储更大范围的整数,范围 -214748364…...
OpenHarmony 开源鸿蒙北向开发——linux使用make交叉编译第三方库
这几天搞鸿蒙,需要编译一些第三方库到鸿蒙系统使用。 头疼死了,搞了一个多星期总算搞定了。 开贴记坑。 一、SDK下载 1.下载 在linux下使用命令 wget https://cidownload.openharmony.cn/version/Master_Version/OpenHarmony_5.1.0.54/20250313_02…...
向量库特点和使用场景
开源的专用向量数据库 Milvus 特点:开源分布式向量数据库,性能强大,支持多种索引类型(如IVF、HNSW等)、多种距离度量和灵活的查询方式,社区活跃,功能丰富,适用于处理大规模向量数据和复杂的检索任务。适用场景:适用于需要高性能、高扩展性的向量检索场景,如大型AI应用…...
【第14届蓝桥杯C/C++B组省赛】01串的熵
问题描述 算法思想 首先分析题目中给出的公式 S 100时,其信息熵为 H(S)−p(0)log2(p(0)) − p(0)log2(p(0)) − p(1)log2(p(1)) 继续化简公式得 设0出现的次数为x,1出现的次数为3-x H(S)−x * p(0) * log2(p(0)) − (3-x) * p(1) * log2(p(1)…...
鸿蒙harmonyOS笔记:练习CheckBoxGroup获取选中的值
除了视觉效果实现全选和反选以外,咱们经常需要获取选中的值,接下来看看如何实现。 核心步骤: 1. 给 CheckBoxGroup 注册 onChange。 2. CheckBox 添加 name 属性。 3. 在 onChange 的回调函数中获取 选中的 name 属性。 事件:…...
收数据花式画图plt实战
目录 Python plt想把纵坐标化成对数形式代码 子图ax. 我又有ax scatter,又有ax plot,都要去对数 数字接近0,取对数没有定义,怎么办 创建数据 添加一个小的常数以避免对数未定义的问题 创建一个figure和一个子图ax 在子图a…...
系统架构书单推荐(一)领域驱动设计与面向对象
本文主要是个人在学习过程中所涉猎的一些经典书籍,有些已经阅读完,有些还在阅读中。于我而言,希望追求软件系统设计相关的原则、方法、思想、本质的东西,并希望通过不断的学习、实践和积累,提升自身的知识和认知。希望…...
Centos6配置yum源
Centos6配置yum源 为Centos6配置CentOS Vault源—防止yum源过期为Centos6配置epel源为Centos6配置ELRepo源---已ELRepo被官方清空Centos6安装dockerdocker配置国内镜像加速 为Centos6配置CentOS Vault源—防止yum源过期 参考:https://mirrors.ustc.edu.cn/help/cen…...
CVPR 2025 | 文本和图像引导的高保真3D数字人高效生成GaussianIP
小小宣传一下CVPR 2025的工作GaussianIP。 arXiv:https://arxiv.org/abs/2503.11143 Github:https://github.com/silence-tang/GaussianIP 欢迎star, issue~ 摘要 文本引导的3D人体生成随着高效3D表示及2D升维方法(如SDS)的发展…...
MySQL密码修改的全部方式一篇详解
本文将详细介绍多种修改MySQL密码的方式。 本文目录 一、alter user 语句操作步骤 二、set password操作步骤 三、直接修改 mysql.user表操作步骤 一、alter user 语句 当你以 root 用户或者拥有足够权限的用户登录 MySQL 时,可以使用 ALTER USER 语句来修改密码。…...
Cursor从小白到专家
文章目录 1:简单开发一个贪吃蛇游戏规则设置提示词 cursor开发小工具开发整体步骤创建.cursorrules输入提示词composer模式chat模式 执行cursor accept all发布到线上进行分享 cursor开发一个浏览器插件创建.cursorrulescursor rules范例集工具 输入提示词执行curso…...
使用C++在Qt框架下调用DeepSeek的API接口实现自己的简易桌面小助手
项目背景 随着DeepSeek的爆火,最近的DeepSeek也进行了新一轮技术的更新,为了拥抱新时代,我们也要不断学习新的知识,难的底层原理我们接触不到,简单的调用还能难住我们? 因为在网络上搜集到的资源都是用Py…...
Kotlin 协程基础知识汇总(一)
1、协程基础 Kotlin 是一门仅在标准库中提供最基本底层 API 以便其他库能够利用协程的语言。与许多其他具有类似功能的语言不同,async 与 await 在 Kotlin 中并不是关键字,甚至都不是标准库的一部分。此外,Kotlin 的挂起函数概念为异步操作提…...
Deepseek训练成AI图片生成机器人
目录 内容安全层 语义理解层 提示词工程层 图像生成层 交付系统 训练好的指令(复制就可以) 内容安全层 理论支撑:基于深度语义理解的混合过滤系统 敏感词检测:采用BERT+CRF混合模型,建立三级敏感词库(显性/隐性/文化禁忌),通过注意力机制捕捉上下文关联风险 伦…...
关于MTU的使用(TCP/IP网络下载慢可能与此有关)
参考链接:告诉你mtu值怎么设置才能网速最好! -Win7系统之家 出现网络速度被限制,可能与MTU值相关,先查看下本机的MTU winR,然后输入:netsh interface ipv4 show subinterfaces ,查看自己网络中的MTU&…...
【信息系统项目管理师】【高分范文】【历年真题】论信息系统项目的风险管理
【手机端浏览】☞【信息系统项目管理师】【高分范文】【历年真题】论信息系统项目的风险管理 2023年上半年考题 【题目】 论信息系统项目的风险管理 项目风险管理旨在识别和管理未被项目计划及其他过程所管理的风险,如果不妥善管理,这些风险可能导致项…...
Debain-12.9使用vllm部署内嵌模型/embedding
Debain-12.9使用vllm部署内嵌模型/embedding 基础环境准备下载模型部署模型注册dify模型 基础环境准备 基础环境安装 下载模型 modelscope download --model BAAI/bge-m3 --local_dir BAAI/bge-m3部署模型 vllm serve ~/ollama/BAAI/bge-m3 --served-model-name bge-m3 --t…...
香橙派连接摄像头过程
在香橙派上下载NoMachine 在控制电脑上也下载NoMachine sudo nmcli dev wifi connect "你的WiFi名称" password "你的WiFi密码" 连接上wifi后就可以在NoMachine连上香橙派了 (不过前提是香橙派有安装桌面端系统(非仅窗口端&…...
Milvus学习整理
Milvus学习整理 一、度量类型(metric_type) 二、向量字段和适用场景介绍 三、索引字段介绍 (一)、概述总结 (二)、详细说明 四、简单代码示例 (一)、建立集合和索引示例 (二)…...
MySQL事务全解析:从概念到实战
在数据库操作中,事务是一个至关重要的概念,它确保了数据的完整性和一致性。今天,就让我们深入探讨MySQL事务的方方面面,从基础概念到实际应用,全面掌握这一技能。 一、为什么需要事务 假设张三要给李四转账100元&…...
重叠构造函数 、JavaBean模式、建造者模式、Spring的隐性大手
构造函数 重叠构造函数JavaBean模式建造者模式构造Spring看起来为什么简单番外篇为什么在JavaBean中 无参构造函数是必须的呢 小结 构造函数对我来讲是很平常的一个东西,今天来谈谈新的收获。 重叠构造函数 通常我们定义好实体类后,不会特意的去调整构造…...
题单:精挑细选
题目描述 小王是公司的仓库管理员,一天,他接到了这样一个任务:从仓库中找出一根钢管。这听起来不算什么,但是这根钢管的要求可真是让他犯难了,要求如下: 1.1. 这根钢管一定要是仓库中最长的; …...
GGUF 和 llama.cpp 是什么关系
这是个非常关键的问题,咱们来细说下:GGUF 和 llama.cpp 是什么关系,它们各自干什么,如何配合工作。 🔧 一、llama.cpp 是什么? llama.cpp 是 Meta 的开源大语言模型 LLaMA(Language Model from…...
手机怎么换网络IP有什么用?操作指南与场景应用
在数字化时代,手机已经成为我们日常生活中不可或缺的一部分,无论是工作、学习还是娱乐,手机都扮演着至关重要的角色。而在手机的使用过程中,网络IP地址作为设备在互联网上的唯一标识符,其重要性和作用不容忽视。本文将…...
强化学习中的深度卷积神经网络设计与应用实例
I. 引言 强化学习(Reinforcement Learning,RL)是机器学习的一个重要分支,通过与环境的交互来学习最优策略。深度学习,特别是深度卷积神经网络(Deep Convolutional Neural Networks,DCNNs&#…...
软考程序员-操作系统基本知识核心考点和知识重点总结
以下是软考程序员考试中操作系统基本知识章节的核心考点和知识重点总结,结合历年真题和考试大纲整理而成: 一、操作系统基本概念与功能 定义与作用 操作系统是管理计算机软硬件资源的核心系统软件,负责协调程序执行、优化资源利用,…...
思源配置阿里云 OSS 踩坑记
按照正常的配置IAM,赋予OSS权限,思源笔记还是无法使用,缺少ListBuckets权限。 正常配置权限,又无法覆盖,因此需要手动配置权限。 {"Version": "1","Statement": [{"Effect":…...
科技赋能安全:慧通测控的安全带全静态性能测试
汽车的广泛普及给人们的出行带来了极大便利,但交通事故频发也成为严重的社会问题。据世界卫生组织统计,全球每年约有 135 万人死于道路交通事故,而安全带在减少事故伤亡方面起着不可替代的作用。正确使用安全带可使前排驾乘人员的死亡风险降低…...
记录修复一个推拉门滑轮
推拉门有个滑轮的固定螺丝不知什么时候掉了,也找不到,这就导致推拉门卡在轨道上。 这种滑轮在夕夕上很便宜,比哈罗单车还划算,但是现在缺的只是螺丝,如果买就会多出来一个轮… 这种螺丝比较长,大概是m4的…...
压缩壳学习
壳是什么 壳就是软件的一个保护套,防止软件被进行反编译或被轻易地修改。 其作用就是为了保护软件。 常见的大类壳有压缩壳、加密壳、VM 壳的分类。 压缩壳顾名思义就是用来减小软件的文件大小的;加密壳,通过加密软件来保护软件ÿ…...
