百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

用vba公式sub和vbnet方法比较“求最大连续次数”多么相似

yuyutoo 2024-10-12 01:34 10 浏览 0 评论

任务要求:

Excel高手用VBA解决最大数字连续次数,用VBA统计E列中1出现最大连续次数,结果保存H20,用按钮控制结果。

Sub tes3t()
    For Each x In Range("e5:e" & [e65536].End(3).Row)
        If x = 1 Then
            n = n + 1
            If k < n Then k = n
        Else
            n = 0
        End If
    Next
    [H22] = k
End Sub

以上代码用sub方式制作,可以完成求1的最大次数。如果单元格中x=1,则累加n+1,并比较K值,如果此时n比k大,则k=n.刷新了最大值。

但其中1是个定值,不方便扩展。如果要求2的最大连续是还要改。

下面我制作一个非常通用的vba自定义函数,来解决这个问题。

Function maxcs(rng As Range, 要查找的值 As Integer) As Integer
   Dim arr, i, n
   Dim k As Integer
   k = 0
   arr = rng.Value
   For i = 1 To UBound(arr, 1)
        If arr(i, 1) = 要查找的值 Then
            n = n + 1
            If k < n Then k = n
        Else
            n = 0
        End If
   Next
   maxcs = k
End Function

主体代码几乎完全一样,只是为了程序健壮性,加了dim声明,并且提供了"要查找的值"作为参数

用以下代码测试下:

Sub test01()
   Dim rng As Range
   Set rng = Sheets(1).Range("E5:E19")
  MsgBox CStr(maxcs(rng, 1))
End Sub

可以正确返回1的最大连续次数5.

在excel表格用公式方法测试:

公式简单明了,普通用户也可以用。比excel公式高手编写的长串公式简明多了。参数变化问题也解决了。

最后一步:收集到vbnet库中

  Function max连续次数(arr(,) As Object, 要查找的值 As Object) As Integer
        Dim i, j, n, k As Integer
        n = 0 : k = 0
        For i = 1 To UBound(arr, 1)
            For j = 1 To UBound(arr, 2)
                If arr(i, j) = 要查找的值 Then
                    n = n + 1
                    If k < n Then k = n
                Else
                    n = 0
                End If
            Next
        Next
        Return k
    End Function

结论:

vba方法适用于sub过程 和function函数,可以完美解决自定义公式的复杂参数问题。

以上方法也可以方便移植到vbnet,一码三用。完全不用重写三遍了。这就是上文我说的vbnet代码兼容vb和vb6。

相关推荐

Python操作Word文档神器:python-docx库从入门到精通

Python操作Word文档神器:python-docx库从入门到精通动动小手,点击关注...

Python 函数调用从入门到精通:超详细定义解析与实战指南 附案例

一、函数基础:定义与调用的核心逻辑定义:函数是将重复或相关的代码块封装成可复用的单元,通过函数名和参数实现特定功能。它是Python模块化编程的基础,能提高代码复用性和可读性。定义语法:...

等这么长时间Python背记手册终于来了,入门到精通(视频400集)

本文毫无套路!真诚分享!前言:无论是学习任何一门语言,基础知识一定要扎实,基础功非常的重要,找一个有丰富编程经验的老师或者师兄带着你会少走很多弯路,你的进步速度也会快很多,无论我们学习的目的是什么,...

图解Python编程:从入门到精通系列教程(附全套速查表)

引言本系列教程展开讲解Python编程语言,Python是一门开源免费、通用型的脚本编程语言,它上手简单,功能强大,它也是互联网最热门的编程语言之一。Python生态丰富,库(模块)极其丰富,这使...

Python入门教程(非常详细)从零基础入门到精通,看完这一篇就够

本书是Python经典实例解析,采用基于实例的方法编写,每个实例都会解决具体的问题和难题。主要内容有:数字、字符串和元组,语句与语法,函数定义,列表、集、字典,用户输入和输出等内置数据结构,类和对象,...

Python函数全解析:从入门到精通,一文搞定!

1.为什么要用函数?函数的作用:封装代码,提高复用性,减少重复,提高可读性。...

Python中的单例模式:从入门到精通

Python中的单例模式:从入门到精通引言单例模式是一种常用的软件设计模式,它保证了一个类只有一个实例,并提供一个全局访问点。这种模式通常用于那些需要频繁创建和销毁的对象,比如日志对象、线程池、缓存等...

【Python王者归来】手把手教你,Python从入门到精通!

用800个程序实例、5万行代码手把手教你,Python从入门到精通!...

Python从零基础入门到精通:一个月就够了

如果想从零基础到入门,能够全职学习(自学),那么一个月足够了。...

Python 从入门到精通:一个月就够了

要知道,一个月是一段很长的时间。如果每天坚持用6-7小时来做一件事,你会有意想不到的收获。作为初学者,第一个月的月目标应该是这样的:熟悉基本概念(变量,条件,列表,循环,函数)练习超过30个编...

Python零基础到精通,这8个入门技巧让你少走弯路,7天速通编程!

Python学习就像玩积木,从最基础的块开始,一步步搭建出复杂的作品。我记得刚开始学Python时也是一头雾水,走了不少弯路。现在回头看,其实掌握几个核心概念,就能快速入门这门编程语言。来聊聊怎么用最...

神仙级python入门教程(非常详细),从0到精通,从看这篇开始!

python入门虽然简单,很多新手依然卡在基础安装阶段,大部分教程对一些基础内容都是一带而过,好多新手朋友,对一些基础知识常常一知半解,需要在网上查询很久。...

Python类从入门到精通,一篇就够!

一、Python类是什么?大家在生活中应该都见过汽车吧,每一辆真实存在、能在路上跑的汽车,都可以看作是一个“对象”。那这些汽车是怎么生产出来的呢?其实,在生产之前,汽车公司都会先设计一个详细的蓝图...

学习Python从入门到精通:30天足够了,这才是python基础的天花板

当年2w买的全套python教程用不着了,现在送给有缘人,不要钱,一个月教你从入门到精通1、本套视频共487集,本套视频共分4季...

30天Python 入门到精通(3天学会python)

以下是一个为期30天的Python入门到精通学习课程,专为零基础新手设计。课程从基础语法开始,逐步深入到面向对象编程、数据处理,最后实现运行简单的大语言模型(如基于HuggingFace...

取消回复欢迎 发表评论: