[ 更换 ]
热门城市
北京上海广州深圳成都杭州南京武汉天津西安重庆青岛沈阳长沙大连厦门无锡福州济南宁波昆明苏州郑州长春合肥南昌哈尔滨常州烟台南宁温州石家庄太原珠海南通扬州贵阳东莞徐州大庆佛山威海洛阳淮安呼和浩特镇江潍坊桂林中山临沂咸阳包头嘉兴惠州泉州三亚赣州九江金华泰安榆林许昌新乡舟山慈溪南阳聊城海口东营淄博漳州保定沧州丹东宜兴绍兴唐山湖州揭阳江阴营口衡阳郴州鄂尔多斯泰州义乌汕头宜昌大同鞍山湘潭盐城马鞍山襄樊长治日照常熟安庆吉林乌鲁木齐兰州秦皇岛肇庆西宁介休滨州台州廊坊邢台株洲德阳绵阳双流平顶山龙岩银川芜湖晋江连云港张家港锦州岳阳长沙县济宁邯郸江门齐齐哈尔昆山柳州绍兴县运城齐河衢州太仓张家口湛江眉山常德盘锦枣庄资阳宜宾赤峰余姚清远蚌埠宁德德州宝鸡牡丹江阜阳莆田诸暨黄石吉安延安拉萨海宁通辽黄山长乐安阳增城桐乡上虞辽阳遵义韶关泸州南平滁州温岭南充景德镇抚顺乌海荆门阳江曲靖邵阳宿迁荆州焦作丹阳丽水延吉茂名梅州渭南葫芦岛娄底滕州上饶富阳内江三明淮南孝感溧阳乐山临汾攀枝花阳泉长葛汉中四平六盘水安顺新余晋城自贡三门峡本溪防城港铁岭随州广安广元天水遂宁萍乡西双版纳绥化鹤壁湘西松原阜新酒泉张家界黔西南保山昭通河池来宾玉溪梧州鹰潭钦州云浮佳木斯克拉玛依呼伦贝尔贺州通化朝阳百色毕节贵港丽江安康德宏朔州伊犁文山楚雄嘉峪关凉山雅安西藏四川广东河北山西辽宁黑龙江江苏浙江安徽福建江西山东河南湖北湖南海南贵州云南陕西甘肃青海台湾内蒙古广西宁夏香港澳门
培训资讯网 - 为兴趣爱好者提供专业的职业培训资讯知识
当前位置: 首页 >> 培训 >> 003.VBA过程和函数-干货

003.VBA过程和函数-干货

过程

003.VBA过程和函数-干货

大家好,我是永不止步的老牛。

上一篇我们介绍了VBA的编辑器,本篇我们介绍VBA过程和函数以及MsgBox函数、InputBox函数、InputBox方法(用代码给单元格设置公式)。

前面文章提到过,过程和函数就是执行某些动作的代码组合,在程序运行时完成具体的任务。

过程以Sub开头,以End Sub结束,过程执行一些代码但不返回值。

函数以Function开头,以End Function结束,函数执行一些代码并返回值,函数可以从过程中执行,也可以在Excel工作表中使用,就像Excel内置函数一样在公式中直接使用,Excel中内置了很多函数,但是总有内置函数无法实现的需求,我们可以自己编写代码去实现,建立一些Excel没有的函数。

我们以一个例子开始我们今天的学习,身体质量指数BMI是常用的衡量人体肥胖程度和是否健康的重要标准,BMI正常范围为18.5-23.9,低于18.5为体重过轻,高于23.9为体重过重,BMI=体重(公斤)除以身高的平方(米的平方)。

1.编写一个过程

  • 新建一个文件“过程和函数.xlsx”并打开
  • 打开VBA编辑器并选择VBAProject(过程和函数.xlsx)
  • 在属性窗口,将VBAProject改成SubAndFunction
  • 在工程资源管理器窗口中右键,选择“插入”-“模块”
  • 在属性窗口将“模块1”改成“BMI计算”
  • 在工程资源管理器中,选中“MI计算”,点击顶部菜单“插入”-“过程”

003.VBA过程和函数-干货

在名称处输入“CalculateBMI”,点击确定,关闭添加过程窗体,VBA代码窗口增加了一个过程:

Public Sub CalculateBMI()

End Sub

第一句声明过程名称,默认是关键字Public表示这个过程可以在所有模块的所有过程里访问。关键字Public是可选的。关键字Sub后面是过程名称CalculateBMI和一对空括号。在括号里你可以添加需要传递的参数。过程都要以End Sub语句结束。

如果把Public替换成Private,那么过程只能被“BMI计算”模块里的其它过程调用,而不能被其它模块里的过程调用

我们在过程体内,就是Public Sub CalculateBMI()和End Sub之间,输入计算BMI的代码,首先定义3个变量BMI、Height和Weight,并给Height和Weight赋值,然后计算BMI数值并将BMI值输出至立即窗口,最后用MsgBox函数提示计算完成及BMI值。

Public Sub CalculateBMI()

Dim BMI As Single "BMI值

Dim Height As Single "身高值

Dim Weight As Single "体重值

Height = 1.81

Weight = 66

BMI = Weight / (Height) ^ 2

Debug.Print BMI

MsgBox "身体质量指数BMI计算完成,BMI为" & BMI, vbOKOnly + vbInformation, "提示"

End Sub

将光标定位在过程代码的任何地方,按F5运行过程,立即窗口会输出BMI值,并弹出对话框显示BMI值。

003.VBA过程和函数-干货

在这个过程中用Dim声明变量并明确数据类型是Single,用=将右边的值赋给左边的变量,

“/”是除运算符,“^”表示计算平方,Debug.Print BMI是将变量BMI的值输出到立即窗口,MsgBox是对话框函数,提供给用户一些信息,并支持人机交互。

003.VBA过程和函数-干货

2.使用MsgBox函数

MsgBox函数语法为:MsgBox(prompt[, buttons] [, title] [, helpfile, context])

[]内的参数可以省略,具体参数的含义、参数数值、返回值后面用表格列举,MsgBox函数可以有返回值,有2种调用方式:

A. MsgBox "消息", vbOKOnly, "提示"

B. iReturn =MsgBox("确认删除该条数据吗?", vbYesNo + vbQuestion, "提示")

A相当于只是在界面上显示了一个对话框,提示用户一些信息,用户点击按钮后不做任何处理。

B相当于在界面上显示了一个对话框,将用户点击不同的按钮的值返回给变量iReturn,然后程序可以根据iReturn的值决定后续代码如何执行。

MsgBox 函数参数说明如下图:

003.VBA过程和函数-干货

buttons参数值设置如下图:

003.VBA过程和函数-干货

buttons参数的

  • 第一组值 (0-5) 表示对话框中显示的按钮的数量和类型;
  • 第二组值(16、32、48、64)表示图标样式;
  • 第三组值(0、256、512)用于确定默认按钮;
  • 第四组值(0、4096)用于确定消息框的形式。

用每组数字的一个值加起来就是最终buttons的值。

返回值如下图:

003.VBA过程和函数-干货

MsgBox函数我们先介绍到这里,我们继续我们的编程,前面编写的代码中我们直接给定了身高和体重数值,我们现在需要让用户输入身高和体重,我们将代码修改成这样:

Public Sub CalculateBMI()

Dim BMI As Single "BMI值

Dim Height As Single "身高值

Dim Weight As Single "体重值

Height = InputBox("请输入自己的身高")

Weight = InputBox("请输入自己的体重")

BMI = Weight / (Height) ^ 2

Debug.Print BMI

MsgBox "身体质量指数BMI计算完成,BMI为" & BMI, vbOKOnly + vbInformation + vbMsgBoxRight, "提示"

End Sub

光标定位在过程代码的任何地方,按F5运行过程,会先弹出对话框要求输入身高,输入并确定后,再弹出对话框要求输入体重,输入并确定后,立即窗口会输出BMI值,并弹出对话框显示BMI值。这里我们使用了InputBox函数让用户输入信息。

3.使用InputBox函数

InputBox函数语法:InputBox(prompt, [ title ], [ default ], [ xpos ], [ ypos ], [ helpfile, context ])

[]内的参数可以省略。

Prompt:显示在对话框上的信息。

Title:对话框的标题,默认的标题是Mictosoft Excel。

Default:文本框里显示一个默认值,如果忽略,显示空白文本框。

xpos和ypos:对话框在屏幕上出现的位置,如果忽略,显示在当前窗口的中央,xpos决定对话框在屏幕上从左起的水平位置,忽略它时,对话框显示在水平中央,ypos决定对话框在屏幕从上而下的竖直位置,忽略它时,对话框就在竖直大约三分之一的位置。

helpfile和context:和本章前面介绍的MsgBox函数相应的参数使用方法一样。

具体参数说明见下表:

003.VBA过程和函数-干货

明白InputBox函数的用法后,我们将上述代码再修改一下,不使用InputBox函数的默认标题“Mictosoft Excel”。

Public Sub CalculateBMI()

Dim BMI As Single "BMI值

Dim Height As Single "身高值

Dim Weight As Single "体重值

Height = InputBox("请输入一个数值", "输入自己的身高")

Weight = InputBox("请输入一个数值", "输入自己的体重")

BMI = Weight / (Height) ^ 2

Debug.Print BMI

MsgBox "身体质量指数BMI计算完成,BMI为" & BMI, vbOKOnly + vbInformation + vbMsgBoxRight, "提示"

End Sub

4.编译一个函数,并在过程及公式中使用

过程我们先介绍到这里,我们看一下函数,函数也是一种过程,只是函数能返回值函数只能由过程调用或在Excel工作表的的公式中使用,而不能像过程一样用F5或菜单“运行”执行

函数的建立可以像前面介绍的建立过程一样,通过菜单“插入”-“模块”,选择“函数”来建立。

003.VBA过程和函数-干货

也可以自己手工编写代码来建立,我们在模块“BMI计算”的代码窗口,直接输入如下代码:

Public Function GetBMI(w, h As Single) As Single

GetBMI = w / (h) ^ 2

End Function

关键字Function后面是函数名称GetBMI和一对空括号。括号里的w和h是传递给函数的参数,函数以Function开头,以End Function语句结束。

Public表示这个函数可以在所有模块的所有过程里访问,在Excel公式中也可以使用,如果将Public换成Private,那么函数只能被同一模块里的其它过程调用,而不能被其它模块里的过程调用,也不能被Excel公式中使用

最后面的As Single表示函数返回值的数据类型,如果省略,默认成Variant。

函数的返回值就是把要返回的内容赋值给函数名称

如果给参数前加关键字Optional,那么表示这个是可选参数,就是说调用函数时,可以传递这个参数值,也可以不传递,注意的是,如果某个参数设置成可选参数,那么这个参数之后的参数必须都是可选参数。

函数我们先简单介绍这么多,还有按地址和按值传递参数等内容,后续我们用到时再细说。

写好函数后,我们可以修改前面的过程CalculateBMI,在过程中调用函数GetBMI,代码如下:

Public Sub CalculateBMI()

Dim BMI As Single "BMI值

Dim Height As Single "身高值

Dim Weight As Single "体重值

Height = InputBox("请输入一个数值", "输入自己的身高")

Weight = InputBox("请输入一个数值", "输入自己的体重")

BMI = GetBMI(Weight, Height)

Debug.Print BMI

MsgBox "身体质量指数BMI计算完成,BMI为" & BMI, vbOKOnly + vbInformation + vbMsgBoxRight, "提示"

End Sub

F5运行,结果和刚才的一样。

我们看一下Excel公式中如何引用函数GetBMI。

003.VBA过程和函数-干货

大家现在已经了解了过程和函数的写法,以及MsgBox函数InputBox函数的用法。

5.使用InputBox方法

前面说的InputBox函数属于VBA库,在Excel库中有一个InputBox方法,大家可以在对象浏览器中搜索InputBox,搜索结果可以看到2个InputBox,分别属于VBA和Excel。

003.VBA过程和函数-干货

InputBox方法的语法:expression.InputBox (Prompt, Title, Default, Left, Top, HelpFile, HelpContextID, Type)

expression:表示 Application 对象的变量。

参数说明如下图:

003.VBA过程和函数-干货

除了最后一个参数Type,其余参数基本和InputBox函数对应,我们重点说一下Type参数,Type参数的值为下表中的数据:

003.VBA过程和函数-干货

Type设置可以允许用户输入的数据类型,可以是一个值,也可以将多个值相加。 假如允许输入文本和数字,Type就设置为 1 + 2。

如果 Type 为 0,InputBox 返回文本格式的公式,如果 Type 为 4,InputBox 返回True或False,如果 Type 为 8,InputBox 返回 Range 对象,如果是8, 必须使用 Set 语句,将结果分配给 Range 对象,

如果不使用 Set 语句,此变量就会被设置为区域中的值,而不是 Range 对象本身。

如果使用 InputBox 方法提示用户输入公式,必须使用 FormulaLocal 属性,将公式分配给 Range 对象。

InputBox 方法与 InputBox 函数的区别在于,前者可以对用户输入进行选择性验证,并能与 Excel 对象、错误值和公式结合使用。 Application.InputBox 调用的是 InputBox 方法;不带对象限定符的 InputBox 调用的是 InputBox 函数。

如果用户输入的内容和Type设置的不相符,会出提示,确认后,继续等待用户输入。

用下面的示例展示一下Type 为 8时,使用和不使用Set的区别,代码如下,区别效果见动图:

Public Sub TestInputBox()

Dim Value

Dim Value2

Set Value = Application.InputBox(Prompt:="请选择单元格", Type:=8)

Set Value2 = Application.InputBox(Prompt:="请选择单元格", Type:=8)

MsgBox Value

End Sub

003.VBA过程和函数-干货

我们在演示一下Type为0时,如何给一个单元格设置我们动态输入的公式,代码如下,效果见动图:

Public Sub TestInputBox2()

Dim Value

Value = Application.InputBox(Prompt:="请输入BMI公式", Type:=0)

Sheet5.Range("F7").FormulaLocal = Value

End Sub

003.VBA过程和函数-干货

VBA过程和函数以及MsgBox函数、InputBox函数、InputBox方法介绍到这里,今天的内容有点多,大家最好能自己实际练习一下,下一篇文章我们介绍Excel宏。

相关内容

怎么学?如何干?西藏7市(地)委书记在西藏日报发表文章

启航新征程 开创新局面为全面建设社会主义现代化新拉萨努力奋斗自治区党委常委、拉萨市委书记 普布顿珠党的二十大大笔擘画坚持以中国式现代化全面推进中华民族伟大复兴的宏伟蓝图,区党委十届三次全会全面铺开建设美丽幸福西藏、共圆伟大复兴梦想的壮阔实践···

2023年全区智慧旅游专业人才培训班圆满结业

6月2日,自治区旅游发展厅主办的全区智慧旅游专业人才培训班在拉萨圆满结业。培训共历时三天,累计完成全区旅游行政管理部门工作人员及涉旅企业专业技术人员培训100人。本次培训是区旅发厅深入推进学习贯彻习近平新时代中国特色社会主义思想主题教育重要···

徐汇萨迦共同举办大美西藏首届口腔学习班

随着现代医学的发展,口腔健康越来越受到人们的关注,为提高西藏地区口腔技术水平和服务质量,近日,徐汇区牙病防治所和萨迦县中心医院远程连线共同举办首届口腔学习班开班仪式。徐汇区卫生健康委副主任胡强,上海援藏干部、萨迦县委常务副书记、常务副县长沈···

自觉抵制“一对一”“一对多”等学科类培训!哈尔滨中小学生暑期预警来了

17日,记者从哈尔滨市各区教育局获悉,2023年暑假将至,南岗区、道里区、香坊区教育局向家长发出预警,自觉抵制违规培训,各区义务教育阶段学科类培训机构已经全部注销,暑假期间以任何形式开展的学科类培训均属于违规培训。家长要自觉抵制任何机构或个···

哈尔滨市道里区企投局举办“招商大讲堂”专题培训

黑龙江网讯(记者 王惠婷)10月24日,哈尔滨市道里区企投局组织开展“招商大讲堂”专题培训班,全区各招商专班负责同志及业务骨干参加培训。本次培训从实际需求出发,紧紧围绕当前招商工作中的热点、难点,对“什么是招商引资”“道里区的产业结构和主导···

团黑龙江省委举办全省青年文明号青年岗位能手学习宣传贯彻党的二十大精神培训交流会

中国青年报客户端讯(李海涛)为深入学习贯彻党的二十大精神,充分发挥青年文明号、青年岗位能手示范引领作用,在全省职业青年中掀起学习党的二十大精神热潮,11月22日,团黑龙江省委举办全省青年文明号青年岗位能手学习宣传贯彻党的二十大精神培训交流会···

辽宁葫芦岛举办外贸政策培训会推动外贸保稳增量

辽宁省葫芦岛市外贸政策培训会4月3日举办。 辽宁省贸促会供图中新网葫芦岛4月3日电 (李晛)辽宁省葫芦岛市外贸政策培训会4月3日举办。本次活动由辽宁省贸促会支持、葫芦岛市商务局主办,葫芦岛市贸促会、葫芦岛海关、中国出口信用保险辽宁分公司和辽···

山西运城:严查无证校外培训机构 查封9家警告2家

新华社太原8月5日电(记者王飞航)记者从山西省运城市政府了解到,运城市教育局近日联合市公安局等多家单位,对中心城区无证校外培训机构进行了一次突击检查,共检查了13家校外培训机构,查封9家,警告2家,发放整改通知书4份。今年7月,运城市教育局···

山西开展培训筑牢森林“防火墙”

山西新闻网3月30日讯(记者 卢奕如)今日,记者从山西省应急管理厅获悉,全省举办森林草原防灭火业务培训,邀请专家以视频会议形式,围绕森林扑火指挥实操、森林草原火灾防控经验做法、火灾现场各级各类指挥员具体操作中遇到的问题等内容进行授课。培训内···

校外培训机构治理工作取得进展 山西停办近1300所

资料图:小学生排队等待进入校园。中新社记者 刘文华 摄中新网5月11日电 据教育部网站消息,按照校外培训机构专项治理工作整体安排,教育部、民政部、国家市场监管总局启动了校外培训机构治理专项督查工作。5月9日至10日,督查组率先在北京市开展华···

山西综改区举办省技术创新中心申报培训

  8月18日,山西综改区科技金融部举办2023年度省技术创新中心申报培训会,来自区内企业、科研院所及有关单位代表160余人参加了培训。  山西省技术创新中心是以产业前沿引领技术和关键共性技术研发为核心的产业技术创新平台,承担着为区域和产业···

山西汾阳医院开展健康教育与控烟知识培训

来源:【吕梁日报-吕梁新闻网】本报讯 (记者 刘少伟) 5月18日,在“世界无烟日”到来之际,山西汾阳医院组织开展健康教育与控烟知识培训。近年来,山西汾阳医院全面落实健康中国战略,根据国家卫健委《关于2011年起全国医疗卫生系统全面禁烟的决···

山西省文物局年度田野考古技术培训班开班

10月10日,山西省文物局在运城闻喜上郭城址、邱家庄墓群举办2023年度田野考古技术培训班开班仪式。该次培训为期三个月,通过理论和实践两部分教学,旨在推进山西考古工作高质量发展,提升考古业务人员专业技术水平。本次培训由山西省考古研究院和山西···

最低每课时9元!全省学科类校外培训课时长和收费标准出台

近日,山西省发改委、省教育厅下发《关于中小学学科类校外培训收费标准及有关事项的通知》,明确全省中小学学科类校外培训收费标准,从12月17日起执行。《通知》对全省线上线下学科类校外培训基准收费标准和浮动幅度制定了科学标准。其中,义务教育阶段线···

山西天镇 阳光职业培训学校培养乡村“新农人”乡村振兴添动能

(记者 贺文生) 山西天镇县阳光职业培训学校紧紧围绕乡村振兴战略,按照“政府引导、农民自愿、立足产业、突出重点”的原则,创新高素质农民技能培训方式方法,采取以“授人以渔”的方式,让人才振兴成为助推农业农村现代化的内生动力,以高素质农民引领现···

山西:建立全过程 全链条 无缝隙安全培训制度

黄河新闻网讯(记者杨江涛)日前,山西省应急管理厅下发了《山西省安全培训管理暂行办法》(以下简称《办法》)。我省将进一步抓好安全生产这个基本盘、基本面,推动全省安全培训工作制度化、规范化、科学化,促进安全培训工作高质量发展。山西省应急管理厅厅···

山西:艺考培训机构纳入全国监管平台管理

央广网太原10月6日消息(记者郎麒) 日前,山西省教育厅、省发改委、省公安厅等部门联合制定《加强面向高中阶段学生艺考培训规范管理工作方案》,针对艺考培训的突出特点和实际情况,全面规范艺考培训行为,将艺考培训机构统一纳入全国校外教育培训监管与···

太平财险阳泉中支开展消防安全教育和有限空间作业培训

为强化员工安全意识,进一步提升员工消防和有限空间突发事件应急处理能力,9月14日,太平财险阳泉中支邀请北京市卫民安消防教育咨询中心山西分中心讲师向全体员工开展了一次消防安全教育和有限空间作业课程培训。按照防消结合、预防为主的原则,本次讲座通···

山西省数字化转型贯标试点工作宣贯培训会在太原举行

  10月20日消息,山西省数字化转型贯标试点工作宣贯培训会在太原举行。省工信厅介绍,作为国家数字化转型贯标试点省份,试点启动后将引导企业加快数字化转型,助力制造业高端化、智能化、绿色化发展。  今年,工信部启动数字化转型贯标试点工作,我省···

山西马兰花创业培训讲师大赛收官 太原市获多个奖项

山西新闻网8月31日讯(记者 冯耿姝)8月29日,山西省第四届马兰花创业培训讲师大赛圆满收官,太原市代表队在比赛中分获多个二、三等奖和优秀奖。本届大赛以“启迪创新思维·激发创业梦想”为主题,全省共有56名教师晋级复赛,其中,太原市有7名选手···