热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

VBA实战技巧精粹002:如何调用过程

在使用VBA编写过程时,一个好的习惯是尽量将实现单独功能的代码放置在独立的过程中,并在主过程中调用这些独立的过程.这样不仅便于程序的高度,而且程序的结构清晰,便于理解和维护,也能够重复使用通用的过

在使用VBA编写过程时,一个好的习惯是尽量将实现单独功能的代码放置在独立的过程中,并在主过程中调用这些独立的过程.这样不仅便于程序的高度,而且程序的结构清晰,便于理解和维护,也能够重复使用通用的过程代码.

通过一个示例演示在程序中调用过程的方法.如图所示工作表,其中"加班费基数"固定,每个加班为80元,"加班数"由人工输入,"加班系数"根据加班个数而不同."加班费"为"加班费基数"和"加班数"分别与"加班系数"的乘积.

要求:自动根据"加班数"确定"加班系数"并得到"加班费"的数值,然后将最大加班费数值所在单元格的底纹设置为绿色.

①解决利用过程及函数获取加班系数问题:

Option Explicit
Dim lLastRow As Integer
Sub 加班费计算()
    Worksheets("sheet1").Activate
    lLastRow = Range("A65536").End(xlUp).Row
    Range("D3:E" & lLastRow).ClearContents
    '调用获取加班系数的过程
    Call GetExtraNum
'    '调用计算加班费的过程
'    Call CalculaeExtra
'    Set rng = Range("E3:E" & lLastRow)
'    '调用设置加班费列格式的过程
'    Call SetFormat(rng)
End Sub

'获取加班系数填入工作表
Sub GetExtraNum()
    Dim i As Integer, ExtraNum As Single
    For i = 3 To lLastRow
        ExtraNum = Range("c" & i).Value
        Range("D" & i).Value = GetExtra(ExtraNum)
    Next i
End Sub
   
'获取加班系数
Function GetExtra(num As Single) As Single
    Select Case num
        Case 1, 2
            GetExtra = 1
        Case 3 To 5
            GetExtra = 1.05
        Case Is > 5
            GetExtra = 1.1
        Case Else
            GetExtra = 0
    End Select
End Function
    
运行以上程序,可以在工作表中填入加班系数.

反思:在数据传递过程中,要特别注意数据类型的一致性,对于小批量的数据运算,最好统一设置成Single类型,少用Integer类型.

②计算加班费并填入相应单元格
'计算加班费并填入指定位置
Sub CalculaeExtra()
    Range("E3:E" & lLastRow).FormulaR1C1 = "=RC2*RC3*RC4"
End Sub
 
这里遇到新情况:关于FormulaR1C1方法的使用.
FormulaR1C1是公式输入方法,上例中为绝对引用
例:C1单元格为"=$A$2+$E$3"  
Range("C1").FormulaR1C1 = "=R2C1+R3C5" 表示将单元格A2与E3相加并赋给C1单元格.
那上例中如何解释呢?看字面就是将第2列/第3列/第4列的值相乘,并赋给同一行的中第E列.
中括号是相对于选定单元格的相对偏移量,"-"为向左或向上偏移,正数为右或下偏移。
无中括号为相对于选定单元格的绝对偏移量,没有负数
"R"和"C"待变“行”和“列”
如:选定单元格为C8
R[-1]C[-1]为B7单元格,行列都-1,R[1]C[2]为E9单元格,行+1,列+2
R1C1代表A1单元格,R5C6代表F5单元格
清楚了吗?

例:C1单元格为"=A1+B1"
Range("C1").FormulaR1C1 = "=RC[-2]+RC[-1]"

例:C1单元格为"=A2+E3"
Range("C1").FormulaR1C1 = "=R[1]C[-2]+R[2]C[2]"
完整程序如下:
Option Explicit
Dim lLastRow As Integer
Sub 加班费计算()
    Worksheets("sheet1").Activate
    lLastRow = Range("A65536").End(xlUp).Row
    Range("D3:E" & lLastRow).ClearContents
    '调用获取加班系数的过程
    Call GetExtraNum
    '调用计算加班费的过程
    Call CalculaeExtra
'    Set rng = Range("E3:E" & lLastRow)
'    '调用设置加班费列格式的过程
End Sub
'获取加班系数填入工作表
Sub GetExtraNum()
    Dim i As Integer, ExtraNum As Single
    For i = 3 To lLastRow
        ExtraNum = Range("c" & i).Value
        Range("D" & i).Value = GetExtra(ExtraNum)
    Next i
End Sub
'获取加班系数
Function GetExtra(num As Single) As Single
    Select Case num
        Case 1, 2
            GetExtra = 1
        Case 3 To 5
            GetExtra = 1.05
        Case Is > 5
            GetExtra = 1.1
        Case Else
            GetExtra = 0
    End Select
End Function
'计算加班费并填入指定位置
Sub CalculaeExtra()
    Range("E3:E" & lLastRow).FormulaR1C1 = "=RC2*RC3*RC4"
End Sub

效果截图:


   
菊子曰 这就是 菊子曰啦!

推荐阅读
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了[从头学数学]中第101节关于比例的相关问题的研究和修炼过程。主要内容包括[机器小伟]和[工程师阿伟]一起研究比例的相关问题,并给出了一个求比例的函数scale的实现。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
author-avatar
Horizonfeng_121
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有