Excel与VBA编程中的常用代码用过VB的人都应该知道如何声明变量,在VBA中声明变量和VB中是完全一样的!使用Dim语句Dimaasinteger'声明A为整形变量Dima'声明A为变体变量Dimaasstring'声明A为字符串变量Dima,b,cascurrency'声明A,b,c为货币变量......声明变量可以是:Byte、Boolean、Integer、Long、Currency、Single、Double、Decimal(当前不支持)、Date、String(只限变长字符串)、String*length(定长字符串)、Object、Variant、用户定义类型或对象类型。强制声明变量OptionExplicit说明:该语句必在任何过程之前出现在模块中。--------------------------------------------------------------------------------声明常数,用来代替文字值。Const'常数的默认状态是Private。ConstMy=456'声明Public常数。PublicConstMyString=HELP'声明PrivateInteger常数。PrivateConstMyIntAsInteger=5'在同一行里声明多个常数。ConstMyStr=Hello,MyDoubleAsDouble=3.4567--------------------------------------------------------------------------------在EXCEL97中,有一个十分好的功能,他就是把鼠标放置在一个有效数据单元格中,执行该段代码,你就可以将连在一起的一片数据全部选中。只要将该段代码加入到你的模块中。SubMy_SelectSelection.CurrentRegion.SelectEndsub--------------------------------------------------------------------------------删除当前单元格中数据的前后空格。submy_trimTrim(ActiveCell.Value)endsub--------------------------------------------------------------------------------使单元格位移submy_offsetActiveCell.Offset(0,1).Select'当前单元格向左移动一格ActiveCell.Offset(0,-1).Select'当前单元格向右移动一格ActiveCell.Offset(1,0).Select'当前单元格向下移动一格ActiveCell.Offset(-1,0).Select'当前单元格向上移动一格endsub如果上述程序产生错误那是因为单元格不能移动,为了解除上述错误,我们可以往submy_offset之下加一段代码onerrorresumenext--------------------------------------------------------------------------------注意以下代码都不再添加sub“代码名称”和endsub请自己添加!给当前单元格赋值:ActiveCell.Value=你好!!!给特定单元格加入一段代码:例如:在A1单元格中插入HELLORange(a1).value=hello又如:你现在的工作簿在sheet1上,你要往sheet2的A1单元格中插入HELLO1.sheets(sheet2).selectrange(a1).value=hello或2.Sheets(sheet1).Range(a1).Value=hello说明:1.sheet2被打开,然后在将“HELLO放入到A1单元格中。2.sheet2不被打开,将“HELLO放入到A1单元格中。--------------------------------------------------------------------------------隐藏工作表'隐藏SHEET1这张工作表sheets(sheet1).Visible=False'显示SHEET1这张工作表sheets(sheet1).Visible=True--------------------------------------------------------------------------------有时候我们想把所有的EXCEL中的SHEET都打印预览,请使用该段代码,它将在你现有的工作簿中循环,直到最后一个工作簿结束循环预览。DimmyAsWorksheetForEachmyInWorksheetsmy.PrintPreviewNextmy--------------------------------------------------------------------------------得到当前单元格的地址msgboxActiveCell.Address--------------------------------------------------------------------------------得到当前日期及时间msgboxdate&chr(13)&time--------------------------------------------------------------------------------保护工作簿ActiveSheet.Protect取消保护工作簿ActiveSheet.Unprotect--------------------------------------------------------------------------------给当前工作簿改名为liuActiveSheet.Name=liu--------------------------------------------------------------------------------打开一个应用程序AppActivate(Shell(C:\WINDOWS\CALC.EXE))--------------------------------------------------------------------------------增加一个工作簿Worksheets.Add删除当前工作簿activesheet.delete-------------------------------------------------------------------------------打开一个文件Workbooks.OpenFileName:=C:\MyDocuments\Book2.xls关闭当前工作簿ActiveWindow.Close--------------------------------------------------------------------------------当前单元格定为:左对齐Selection.HorizontalAlignment=xlLeft当前单元格定为:中心对齐Selection.HorizontalAlignment=xlCenter当前单元格定为:右对齐Selection.HorizontalAlignment=xlRight--------------------------------------------------------------------------------当前单元格为百分号风格Selection.Style=Percent--------------------------------------------------------------------------------当前单元格字体为粗体Selection.Font.Bold=True当前单元格字体为斜体Selection.Font.Italic=True当前单元格字体为宋体20号字WithSelection.Font.Name=宋体.Size=20EndWith--------------------------------------------------------------------------------With语句With对象.描述EndWith--------------------------------------------------------------------------------让你的机器发出响声BEEP--------------------------------------------------------------------------------清除单元格中所有文字、批注、格式、所有的东西!ActiveCell.Clear--------------------------------------------------------------------------------测试选择状态的单元格的行数MsgBoxSelection.Rows.Count测试选择状态的单元格的列数MsgBoxSelection.Columns.Count--------------------------------------------------------------------------------测试选择状态的单元格的地址Selection.Address--------------------------------------------------------------------------------让所有的错误不再发生ONERRORRESUMENEXT--------------------------------------------------------------------------------产生错误时让错误转到另一个地方onerrorgotol'codel:'code--------------------------------------------------------------------------------删除一个文件killc:\1.txt--------------------------------------------------------------------------------定制自己的状态栏Application.StatusBar=现在时刻:&Time恢复自己的状态栏Application.StatusBar=false--------------------------------------------------------------------------------在运行期执行一个宏Application.Runmacro:=text--------------------------------------------------------------------------------滚动窗口到a1的位置ActiveWindow.ScrollRow=1ActiveWindow.ScrollColumn=1--------------------------------------------------------------------------------定制系统日期DimMyDate,MyDayMyDate=#12/12/69#MyDay=Day(MyDate)----------------------------------------------------------------------------