Excel 宏编程的常用代码

Excel 宏编程的常用代码Excel宏编程的常用代码我们常用Excel统计一些数据,如果善用VBA,就能自动做出各种复杂的报表,懒人就是追求一劳永逸!不过,也不是真懒啦,只是用智慧(脑力劳动)将自身从体力劳动中解放出来而已,人类也是这样进步的。我有这样的感觉,就是每见到一个语句或函数,都会激发出偷懒的灵感来,哈哈,很自恋了,其实好玩而已。————————-

大家好,又见面了,我是你们的朋友全栈君。

Excel 宏编程的常用代码

我们常用Excel统计一些数据,如果善用VBA,就能自动做出各种复杂的报表,懒人就是追求一劳永逸!不过,也不是真懒啦,只是用智慧(脑力劳动)将自身从体力劳动中解放出来而已,人类也是这样进步的。我有这样的感觉,就是每见到一个语句或函数,都会激发出偷懒的灵感来,哈哈,很自恋了,其实好玩而已。

————————————————————————-

用过VB的人都应该知道如何声明变量,在VBA中声明变量和VB中是完全一样的!
使用Dim语句
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、用户定义类型或对象类型。

强制声明变量
Option Explicit
说明:该语句必在任何过程之前出现在模块中。

声明常数
用来代替文字值。
Const

‘ 常数的默认状态是 Private。
Const My = 456

‘ 声明 Public 常数。
Public Const MyString = “HELP”

‘ 声明 Private Integer 常数。
Private Const MyInt As Integer = 5

‘ 在同一行里声明多个常数。
Const MyStr = “Hello”, MyDouble As Double = 3.4567

选择当前单元格所在区域

在EXCEL97中,有一个十分好的功能,他就是把鼠标放置在一个有效数据单元格中,执行该段代码,你就可以将连在一起的一片数据全部选中。只要将该段代码加入到你的模块中。
Sub My_Select
Selection.CurrentRegion.Select
End sub

 

返回当前单元格中数据删除前后空格后的值
sub my_trim
msgbox Trim(ActiveCell.Value)
end sub

 

单元格位移
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
如果上述程序产生错误那是因为单元格不能移动,为了解除上述错误,我们可以往
sub my_offset 之下加一段代码 on error resume next

 

注意以下代码都不再添加 sub “代码名称” 和end sub请自己添加!

给当前单元格赋值
ActiveCell.Value = “你好!!!”

 

给指定单元格赋值
例如:A1单元格内容设为”HELLO”
Range(“a1″).value=”hello”

又如:你现在的工作簿在sheet1上,你要往sheet2的A1单元格中插入”HELLO”
1.
sheets(“sheet2”).select
range(“a1″).value=”hello”

2.
Sheets(“sheet1”).Range(“a1”).Value = “hello”

说明:
1.sheet2被选中,然后在将“HELLO”赋到A1单元格中。
2.sheet2不必被选中,即可“HELLO”赋到sheet2 的A1单元格中。

 

隐藏工作表
‘隐藏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

 

得到当前单元格的地址
msgbox ActiveCell.Address

 

得到当前日期及时间
msgbox date & chr(13) & time

 

保护工作簿
ActiveSheet.Protect

 

取消保护工作簿
ActiveSheet.Unprotect

 

给活动工作表改名为 “liu”
ActiveSheet.Name = “liu”

 

打开一个应用程序
AppActivate (Shell(“C:/WINDOWS/CALC.EXE”))

 

增加一个工作表
Worksheets.Add

 

删除活动工作表
activesheet.delete

 

打开一个工作簿文件
Workbooks.Open FileName:=”C:/My Documents/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号字
With Selection.Font
.Name = “宋体”
.Size = 20
End With

With 语句

With 对象
.描述
End With

 

清除单元格
ActiveCell.Clear ‘删除所有文字、批注、格式

返回选定区域的行数
MsgBox Selection.Rows.Count

 

返回选定区域的列数
MsgBox Selection.Columns.Count

返回选定区域的地址
Selection.Address

 

忽略所有的错误
ON ERROR RESUME NEXT

 

遇错跳转
on error goto err_handle
‘中间的其他代码
err_handle: ‘ 标签
‘跳转后的代码

 

删除一个文件
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

 

冻结窗口

Range(“A2”).Select
ActiveWindow.FreezePanes = True

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/131935.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(1)


相关推荐

  • pycharm双击打不开,没有反应,下列方法亲测有用!

    pycharm双击打不开,没有反应,下列方法亲测有用!关于这个问题,刚好我朋友安装的pycharm出现了同样地问题,激活成功教程安装一段时间后就突然打不开了,网上有许多的解决办法,我都试了一遍还是无果,后来自己发现了问题所在,首先给大家科普一下网上的方法,再放上我的,请大家耐心读完。亲测有效!!!第一种:1.打开C:\Windows\System32;以管理员身份运行cmd.exe;2.在打开的cmd窗口中,输入netshwinsockreset,按回车键;3.重启电脑;4.重启后,双击pycharm图标就能打开了!第二种:在Pycha

  • visifire 使用备忘

    visifire 使用备忘//图表绑定辅助类publicclassChartValue:INotifyPropertyChanged{publicChartValue(){}publicChartValue(stringxlabel,decimalvalue){Label=xlabel;_yValue=value;}de…

  • Intellij IDEA快捷键生成Getter、Setter和构造器[通俗易懂]

    Intellij IDEA快捷键生成Getter、Setter和构造器[通俗易懂]隔一个暑假不用,再次使用Idea快捷键都忘的差不多了。特此记录下快捷键生成Getter/Setter等。Alt + Insert 组合,可唤出选择面板:选择自己需要的即可。…

  • cmd命令如何切换盘符_cmd命令修改盘符

    cmd命令如何切换盘符_cmd命令修改盘符返回上一级目录:cd..进入盘符根目录(例如进入E盘): e:

  • LDR命令

    LDR命令  LDR指令用于从内存中将一个32位的字读取到指令中的目标寄存器中,如果目标寄存器为PC,则可以实现“长”跳转。主要有一下3种方式使用:ldrr0,_startldrr0,=_startldrpc,_start  逐条分析:一、ldrr0,_start  从内存地址_start的地方,把其对应的命令执行对应的“执行码”读入到r0中。二、ldrr0,=_start  …

  • 解决P2P传输瓶颈

    解决P2P传输瓶颈随着嵌入式技术这几年的迅速发展,在个人电脑平台上正显示出强大市场需求的流媒体技术,目前逐渐有向嵌入式平台转移的趋势。个人便携化、家电化的媒体消费需求,为这次平台的转移提供了市场契机。IPTV正是在这场消费革命中处在风口浪尖的焦点。业内大多认为IPTV蕴含了巨大的商业利益,但至今仍鲜有涉足者,其中原因之一是网络速度问题。本文介绍了对等网络技术,即点对点(P2P)技术,将其应用到IPTV网络传输中,可

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号