一、声明变量
Dim a as integer '声明a为整型变量
Dim a '声明a为变体变量
Dim a as string '声明a为字符串变量
Dim a as currency ,b as currency ,c as currency '声明a,b,c为货币变量
声明变量可以是:Byte、Boolean、Integer、Long、Currency、Single、Double、Decimal(当前不支持)、Date、String(只限变长字符串)、String * length(定长字符串)、Object、Variant、用户定义类型或对象类型。
二、声明常数
ConstConst My = 456 '常数的默认状态是 Private。
Public Const MyString = "HELP" ' 声明 Public 常数。
Private Const MyInt As Integer = 5 ' 声明 Private Integer 常数。
Const MyStr = "Hello", MyDouble As Double = 3.4567 ' 在同一行里声明多个常数。
三、行数列数
查看行数:hang=sheet.UsedRange.Rows.Count
EndRow = Sheets(sheetsCaption).Range(Col & "65536").End(xlUp).Row
查看列数:lie=sheet.UsedRange.Columns.Count
返回选定区域的行数:MsgBox Selection.Rows.Count
返回选定区域的列数:MsgBox Selection.Columns.Count
返回选定区域的地址:Selection.Address
四、赋值:
Workbooks("12.xls").Worksheets("sheet2").Range("B5").Value = "abcde"
Sheets("sheet1").Range("a1").Value = "hello"
sheets("sheet2").select
Range("a1").value="hello"
Sheets("sheet1").Range("a1")select
ActiveCell.Value = "你好!!!"
五、工作表相关:
ActiveSheet.Name = "liu" '给活动工作表改名"liu"
Worksheets.Add '增加一个工作表
activesheet.delete '删除活动工作表
Workbooks.Open FileName:="C:\My Documents\Book2.xls" '打开一个工作簿文件
ActiveWindow.Close '关闭活动窗口
With Sheets("sheet1") '设定操作区域
End With
示例:
六、行的操作:
Rows(i & ":" & i).Select '剪切I行到4行上面
Selection.Cut
Rows("4:4").Select
Selection.Insert Shift:=xlDown
七、单元格位移:
sub my_offset
ActiveCell.Offset(0, 1).Select'当前单元格向左移动一格
ActiveCell.Offset(0, -1).Select'当前单元格向右移动一格
ActiveCell.Offset(1 , 0).Select'当前单元格向下移动一格
ActiveCell.Offset(-1 , 0).Select'当前单元格向上移动一格
end sub
八、单元格的设置:
Range("A5").Select '设置成红色
With Selection.Interior
.ColorIndex = 3
九、报错:
如果上述程序产生错误那是因为单元格不能移动,为了解除上述错误,我们可以往
sub my_offset 之下加一段代码 on error resume next
忽略所有的错误
ON ERROR RESUME NEXT
遇错跳转:
on error goto err_handle
'中间的其他代码
err_handle: ' 标签
'跳转后的代码
十、单元格格式:
ActiveCell.Clear '清除单元格:删除所有文字、批注、格式
Selection.HorizontalAlignment = xlLeft '选定单元格左对齐
Selection.HorizontalAlignment = xlCenter '选定单元格居中
Selection.HorizontalAlignment = xlRight '选定单元格右对齐
Selection.Style = "Percent" '选定单元格为百分号风格
Selection.Font.Bold = True '选定单元格字体为粗体
Selection.Font.Italic = True '选定单元格字体为斜体
With Selection.Font '选定单元格字体为宋体20号字
.Name = "宋体"
.Size = 20
End With
msgbox ActiveCell.Address '得到当前单元格的地址
msgbox date & chr(13) & time '得到当前日期及时间
十一、VBA专属特性:
删除一个文件:kill "c:\1.txt"
定制自己的状态栏:Application.StatusBar = "现在时刻: " & Time
恢复自己的状态栏:Application.StatusBar = false
用代码执行一个宏:Application.Run macro:="text"
滚动窗口到a1的位置:ActiveWindow.ScrollRow = 1:ActiveWindow.ScrollColumn = 1
定制系统日期
Dim MyDate, MyDay
MyDate = #12/12/69#
MyDay = Day(MyDate)
返回当天的时间
Dim MyDate, MyYear
MyDate = Date
MyYear = Year(MyDate)
MsgBox MyYear
inputbox<输入框>:XX=InputBox ("Enter number of months to add")
得到一个文件名
Dim kk As String
kk = Application.GetOpenFilename("EXCEL (*.XLS), *.XLS", Title:="提示:请打开一个EXCEL文件:")
msgbox kk
打开zoom(显示比例)对话框:Application.Dialogs(xlDialogZoom).Show
激活字体对话框:Application.Dialogs(xlDialogActiveCellFont).Show
打开另存对话框
Dim kk As String
kk = Application.GetSaveAsFilename("excel (*.xls), *.xls")
Workbooks.Open kk
返回当前单元格中数据删除前后空格后的值
sub my_trim
msgbox Trim(ActiveCell.Value)
end sub
保护工作簿:ActiveSheet.Protect
取消保护工作簿:ActiveSheet.Unprotect
打开一个应用程序:AppActivate (Shell("C:\WINDOWS\CALC.EXE"))
隐藏SHEET1这张工作表:sheets("sheet1").Visible=False
显示SHEET1这张工作表:sheets("sheet1").Visible=True
打印预览:有时候我们想把所有的EXCEL中的SHEET都打印预览,请使用该段代码,它将在你现有的工作簿中循环,直到最后一个工作簿结束循环预览。
Dim my As Worksheet
For Each my In Worksheets
my.PrintPreview
Next my
联系客服