高洪皓 庄伟明 宋兰华
摘 要: 在大多数院校,高级办公自动化与宏应用课程作为公共基础课开设,但在教学过程中普遍存在内容繁杂和进度滞后等问题。探讨了以案例教学为向导组织VBA高级应用教学内容,对传统的编程教学模式进行创新。针对宏与自动化录制,宏代码进阶,控件与宏的绑定调用这三个部分,在课堂上实践案例教学,能明显增强学生对面向对象编程技术的理解,提高学生对编程语言的学习兴趣,引导学生将办公自动化知识应用到实践中。
关键词: 高级办公自动化; VBA高级应用; 宏代码; 案例教学
中图分类号:G642 文献标志码:A 文章编号:1006-8228(2015)08-73-03
Research on applying advanced VBA application cases to non-computer majors teaching
Gao Honghao, Zhuang Weiming, Song Lanhua
(Shanghai university computing center, Shanghai 200444, China)
Abstract: Most colleges have opened the advanced office automation and macro application course as a public basic course, but the problem of content complex and progress lag is ubiquitous in the teaching process. This paper takes case teaching as the guide to organize the teaching content of VBA advanced application and to innovate the traditional programming course teaching mode. Taking the macro and its automatic recording, macro code upgrade, binding calls for control and macro three parts as the practice case taught in classroom, can enhance students' understanding of object-oriented programming technology, promote students' interest of learning programming language and guide students to apply the knowledge of office automation to practice.
Key words: advanced office automation; VBA; macro code; case teaching
0 引言
向非计算机专业的学生教授计算机基础知识的目标是要让学生掌握计算机应用技能,将自身的专业知识与计算机技能相结合并更好地服务于专业学科领域。不同专业背景的学生对学习和掌握计算机技能的期望不同,加之学生的计算机基础也不尽相同。因此,在教学实践过程中,对不同专业需要提出不同的要求,同时采用不同的教学方式。
上海大学实行大类招生,在课程改革不断深入的过程中,提高学生学习兴趣、培养学生自主学习、实践及团队协作的能力是摆在我们面前要解决的迫切任务[1]。高级办公自动化与宏应用[2]作为非计算机专业学生的计算机基础课,教师主要讲授微软Word、Excel、PowerPoint软件应用,以及VBA高级应用的程序设计。VBA是Microsoft Office系列的内置编程语言,是开发语言VB(Visual Basic)的一个分支,可供用户编写宏,对Office进行二次开发。由于其是面向对象编程技术,并具有良好的可视化设计效果,因此适合作为非计算机专业学生学习编程的入门语言。由于课程覆盖学生面大,涉及专业类别多,对于如何进行教学改革才能取得好的成果,多年来一直都在研究和探索。在教学过程中发现并归纳了一些问题。一方面,学生对于基础办公软件操作的重视程度不高。对于这部分知识,学生往往浅尝辄止且易于满足,在工作中遇到实际问题时经常无法独立解决。另一方面,绝大多数非计算机专业学生的编程基础薄弱,学生对VBA高级应用部分的学习兴趣低迷,部分学生甚至主动放弃学习这部分课程内容。在教学实践过程中还发现,学生更加容易接受面向应用的案例教学,学生的课堂参与度较之枯燥的理论教学有明显提高。目前,教学模式急需从以VBA理论讲授为中心转变到以案例实践为中心[3-5],对课程的课内授课、课内实验、课外实践等内容作进一步调整与完善,同时设计课程有关的辅助软件或硬件,以帮助学生更快更好地掌握课程内容,提高理论与实践能力。
本文针对VBA高级应用部分的知识点,从教学实际问题出发,选取典型教学案例,构建课程的教学体系。以案例教学为向导,改变传统的编程语言授课模式,力争在较短时间内使教学质量有明显地提高。
1 宏与自动化录制
宏(Macro)是一个程序段,或一个子程序,其由一系列的命令(包括Word、Excel、PPT命令)和指令组成的,是完成特定任务的指令集合,实现任务自动化执行。有两种创建宏的方法:录制宏和编写宏。录制宏是指通过宏录制器的方式进行:宏录制器的打开需要选择选项卡[视图]→[宏]→[录制宏],然后打开宏录制器对话框。如图1所示,是以Excel为例的录制宏对话框,包括宏的名称和保存位置。编写宏是指在Visual Basic编辑器(VBE,Visual Basic Editor)上编写宏代码:可以按组合键“Alt+F11”快速打开编程环境。
图1 以XLS为例的录制宏对话框
录制宏的过程,实际上就是将一系列操作过程记录下来并由系统自动转换为VBA语句。这种方法较为简单,可以满足学生的好奇心和吸引学生的注意力。为了降低学生的理解难度,教学过程中侧重介绍宏录制器,设计案例1并通过分析和现场操作来解释录制宏。
案例1 针对图2的学生成绩表,通过录制宏的方法来设置总分和平均分。要求设置两个按钮,分别是“总分”和“平均分”,当执行“总分”宏时,统计表格中的总分,当执行“平均分”宏时,统计表格中的平均分。
3 控件与宏的绑定调用
宏的调用分两种方式:一种是在VBE环境执行模块,另外一种以Office的控件执行。在案例教学过程中,重点介绍Office控件的按钮与宏调用功能绑定。
案例3:在Sheet1的B5单元格中创建一个 “计算器”按钮,单击该按钮,弹出一个如图3所示的计算器,并能进行简单的四则运算。
图3 计算器界面
首先,打开VBE环境需要执行选项卡[文件]→[选项]→[自定义功能区]→[开发工具],打开开发工具视图选项卡。接着,单击“插入|用户窗体”,插入UserForm1窗体,选中UserForm1窗口,浮现工具箱(如图4所示)。在主窗口中添加相应控件,根据图3示例界面的需要修改控件属性。