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

 

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

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

(1)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • wd移动硬盘不能识别_西数移动硬盘电脑提示无法识别USB设备怎么办「建议收藏」

    展开全部1.造成USB设备无法识别的故障是由于很多原因引起的,包括软、硬件,解决方法32313133353236313431303231363533e58685e5aeb931333337623431如下:首先将usb设备插入计算机接口,然后在桌面左下角单击“开始”菜单,单击“运行”命令,打开框中键入“cmd”命令,单击“确定”按钮。2.启动命令提示符窗口,分别执行以下两条命令regadd”H…

    2022年4月11日
    69
  • 遍历map的四种方法

    遍历map的四种方法 Map.entrySet()这个方法返回的是一个Set<Map.Entry<K,V>>,Map.Entry是Map中的一个接口,他的用途是表示一个映射项(里面有Key和Value),而Set<Map.Entry<K,V>>表示一个映射项的Set。Map.Entry里有相应的getKey和getValue方法,即JavaBean,让我们能够从一个项中取出…

    2022年9月21日
    4
  • Qt quick性能提升[通俗易懂]

    Qt quick性能提升[通俗易懂]Qtquick性能优化使用时间驱动  避免定时轮询;  使用信号槽形式;使用多线程  C++;  QMLWorkerScript元件;使用QtQuickCompiler  只需要再PRO文件中添加一行:CONIFG+=qtquickcompiler避免使用CPU渲染的元件;  Canvas、QtCharts;使用异步加载  图片异步加载…

    2026年2月1日
    2
  • pda手持终端软件下载_成为pda

    pda手持终端软件下载_成为pdaPDAF点亮主要参考《MT6763_MT6757_PDAF_Driver_and_Buf_mgr_Porting_Guide.pdf》1、什么是PDAF1.1PDAF的原理在了解相位对焦PDAF,PhaseDetectionAutoFocus之前,在网上肯定会搜到其他对焦方式。比如对比度对焦(反差对焦)CDAF,ContrastDetectionAutoFocus、激光对焦LDAF,LaserDetectionAutoFocus、双核对焦等。…

    2025年9月23日
    10
  • 如何成为年薪50W的运维架构师?

    如何成为年薪50W的运维架构师?linux云计算工程师三大核心职能平台架构组建负责服务的搭建日常运营保障保证运维工作正常运转出现问题解决性能、效率优化运维工作效率的优化,devops运维自动化提升系统的性能90%服务器都是LinuxLinux免费(windows是付费的,我们用的都是盗版)Linux平台稳定Linux开源过程开发工程师(开发,bug修复,码农)—&gt;…

    2022年7月17日
    18
  • 【《重构 改善既有代码的设计》学习笔记4】构筑测试体系

    本篇文章的内容来自《重构 改善既有代码的设计》一书学习笔记整理并且加上自己的浅显的思考总结!如果想要进行重构,首要前提是 拥有一个可靠的测试环境。1、 自测代码的价值完成一个功能:设计+开发+调试,认真分析,程序员最多花费的时间不是开发(编码),而是用来调试。调试可能花费无数个小时,甚至通宵达旦。修复错误是快速的,而找出错误却是恶梦一场。当修复好一个错误,总是会有另一个错误的出现。而引…

    2022年2月27日
    48

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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