Excel VBA开发基本语句说明

前言

VBA(Visual Basic for Applications)是一种用于编写宏的编程语言,它广泛应用于Microsoft Office套件中的各种应用程序,如Excel、Word、Access和PowerPoint等。在这些应用程序中,VBA可用于自动化任务、定制功能、数据处理和报告生成等。

虽然VBA已经存在很长时间,并且被广泛应用于许多组织和行业,但是随着时间的推移,它的使用正在逐渐减少。原因可以归结为以下几点:

  1. 跨平台兼容性:VBA是一种Windows环境下的宏语言,对于其他操作系统,如Mac和Linux,并不完全适用。因此,随着人们对跨平台兼容性的需求增加,其他更通用的编程语言(如Python和JavaScript)在处理类似任务时更受欢迎。
  2. 功能限制:VBA虽然功能强大,但与其他现代编程语言相比,它的功能和性能受到一定的限制。人们对更高效、更灵活的解决方案的需求也推动了其他语言的发展和应用。
  3. Office 365的出现:随着Office 365的发展,微软逐渐将注意力转向了更先进的工具和技术。例如,Power Automate
    和Power Apps等工具提供了更强大和易于使用的方式来自动化任务和定制功能。

尽管如此,VBA仍然在某些特定的行业和组织中得到广泛使用,特别是在那些长期依赖VBA开发的企业和机构

最近在做一些excel vba开发 总结了开发过程操作单元格语法,希望能帮助需要的人

实战总结

访问工作簿:

vbnet 复制代码
Dim wb As Workbook
Set wb = ThisWorkbook

访问工作表:

vbnet 复制代码
Dim ws As Worksheet
Set ws = wb.Worksheets("Sheet1")

引用单个单元格:

vbnet 复制代码
Dim cell As Range
Set cell = ws.Range("A1")

引用单元格范围:

vbnet 复制代码
Dim range As Range
Set range = ws.Range("A1:B5")

引用整行:

vbnet 复制代码
Dim row As Range
Set row = ws.Rows(1)

引用整列:

vbnet 复制代码
Dim column As Range
Set column = ws.Columns(1)

确定工作表中最后一个有数据的单元格所在行数

vbnet 复制代码
ws.Cells(ws.Rows.count, 1).End(xlUp).Row
  • ws.Rows.Count:表示工作表的总行数。
  • 1:表示要访问的列号,这里是列号为1的列(即第一列)。
  • End(xlUp):这是一个定位方法,用于从指定单元格向上搜索,直到找到第一个非空单元格为止。在这个例子中,它会从工作表最后一行向上搜索,找到第一个非空单元格。
  • Row:表示找到的最后一个非空单元格所在的行号。

确定工作表中指定行中最后一个有数据的单元格所在的列数

vbnet 复制代码
scheduleSheetLastColumn = ws.Cells(8, ws.Columns.count).End(xlToLeft).Column
  • 8:表示要访问的行号,这里是第8行。
  • ws.Columns.Count:表示工作表的总列数。
  • End(xlToLeft):这是一个定位方法,用于从指定单元格向左搜索,直到找到第一个非空单元格为止。在这个例子中,它会从指定行的最后一列向左搜索,找到第一个非空单元格。
  • Column:表示找到的最后一个非空单元格所在的列号。

第一列插入一列,并将现有的数据向右移动

vbnet 复制代码
ws.Columns(1).Insert Shift:=xlToRight

引用单元格 K8

vbnet 复制代码
Set tableStartCell = ws.Range("K8")

引用范围对象(K8~K18)

vbnet 复制代码
ws.Range(tableStartCell, tableStartCell.Offset(0, 10))

取消合并单元格

vbnet 复制代码
tableStartCell.UnMerge

设置范围(K8~K18)背景色

将其内部颜色设置为 RGB(255, 255, 0),即黄色

vbnet 复制代码
ws.Range(tableStartCell, tableStartCell.Offset(0, 10)).Interior.Color = RGB(255, 255, 0)

获取单元格地址代码

vbnet 复制代码
ws.Cells(8, 10).Address

合并单元格(K8~K10)

vbnet 复制代码
ws.Range(tableStartCell, tableStartCell.Offset(0, 2)).Merge

● 单元格范围公式复制

获取第 10 行第 11 列和第 10 行第 12 列的单元格的内容

vbnet 复制代码
Dim rangeToCopy1 As Range
Set rangeToCopy1 = ws.Range(ws.Cells(10, 11), ws.Cells(10,  12))

获取第 20 行第 11 列和第 20 行第 12 列的单元格的内容

vbnet 复制代码
Dim destinationRange1 As Range
Set destinationRange1 = ws.Range(ws.Cells(20, 11), ws.Cells(20, 12))

将第 10 行第 11 列和第 10 行第 12 列的单元格的内容复制到第 20 行第 11 列和第 20 行第 12 列的单元格中。

vbnet 复制代码
rangeToCopy1.Copy Destination:=destinationRange1

设置单元格文字样式

获取A1 到 H1 范围内的单元格

vbnet 复制代码
Set rng = ws.Range("A1:H1")

With rng
	.Font.Color = RGB(0, 0, 0)
	.HorizontalAlignment = xlLeft
	.Font.Size = 9
	.Font.Bold = False
End With
  • .Font.Color = RGB(0, 0, 0) 设置字体颜色为黑色。
  • .HorizontalAlignment = xlLeft 设置水平对齐方式为左对齐。
  • .Font.Size = 9 设置字体大小为9号。
  • .Font.Bold = False 取消粗体设置。

大鹏一日同风起 扶摇直上九万里 加油!!!!

End

相关推荐
bin91538 小时前
【EXCEL数据处理】000017 案例 Match和Index函数。
excel
shandianchengzi10 小时前
【记录】Excel|Excel 打印成 PDF 页数太多怎么办
pdf·excel
bin915313 小时前
【EXCEL数据处理】000010 案列 EXCEL文本型和常规型转换。使用的软件是微软的Excel操作的。处理数据的目的是让数据更直观的显示出来,方便查看。
大数据·数据库·信息可视化·数据挖掘·数据分析·excel·数据可视化
一个散步者的梦20 小时前
Excel常用函数
excel
bin91531 天前
【EXCEL数据处理】000009 案列 EXCEL单元格数字格式。文本型数字格式和常规型数字格式的区别
大数据·前端·数据库·信息可视化·数据分析·excel·数据可视化
Eiceblue2 天前
Python保留数据删除Excel单元格的函数和公式
开发语言·python·excel
bin91532 天前
【EXCEL数据处理】000014 案例 EXCEL分类汇总、定位和创建组。附多个操作案例。
信息可视化·数据挖掘·数据分析·excel·数据可视化·数据图表·excel 数据分析
育种数据分析之放飞自我2 天前
GWAS分析中显著位点如何注释基因:excel???
linux·算法·excel
PowerBI学谦2 天前
Python in Excel 正式发布!
开发语言·python·excel
bin91532 天前
【EXCEL数据处理】000011 案列 EXCEL带有三角形图标的单元格转换,和文本日期格式转换。
大数据·数据库·信息可视化·数据挖掘·数据分析·excel·数据可视化