几个VB小程序

Private Sub Command_Click()   'Column_1相等的情况下,Column_2相邻行相减
    Row = 2             '设置开始行值
    Column_1 = 1        '设置需要相减的列值
    Column_2 = 3        '需要将结果数据放置的列值
    Do
        t = Cells(Row, Column_1)
        v = Cells(Row + 1, Column_1)
        If v = "" Then Exit Do
            If t = v Then
                Cells(Row, Column_2) = Cells(Row + 1, 2) - Cells(Row, 2)
            Else: End If
    Row = Row + 1
    Loop
End Sub

 

Private Sub CommandButton1_Click()      '相邻块取最小值
    i = 2      '设置开始行值
    Do
        j = 0    '设置块
        t = Cells(i, 11)
        Do
            v = Cells(i + j + 1, 11)
            If v = 0 Then Exit Do
                If t < v Then          '取最小值
                    Cells(i, 12) = t
                ElseIf t > v Then
                    Cells(i, 12) = v
                    ElseIf t = v Then
                    Cells(i, 12) = t
                End If
            t = Cells(i, 12)
            j = j + 1
        Loop
        If v = "" Then Exit Do    '遇到空行即结束
        i = i + j + 1                    '下一个块行值
    Loop
End Sub

 

Private Sub CommandButton2_Click()   '相隔60秒计数,注意列值为时间
    i = 2   '设置开始行号
    Do
        j = 0    '设置块
        t = Cells(i, 1)    '第i个比较块,列值为1
        Do
            V = Cells(i + j + 1, 1)
            If V = "" Then Exit Do
                If V - t > 60 / 24 / 3600 Then
                j = j + 1
                Exit Do
                Else: End If
            j = j + 1
        Loop
        Cells(i, 3) = j           '结果放在第3列
    If V = "" Then
        Cells(i, 3) = j + 1    '最后一个块自动加1
    Exit Do
    Else: End If
        i = i + j                    '下一个块行值
    Loop
End Sub

Private Sub CommandButton3_Click()   '每隔60秒计数, 列值为时间, 放在第一列
    i = 2           '设置开始行号
    k = 0
    m = Cells(i, 1)
    Do
        j = 0               '设置块
        t = m + k * 60 / 24 / 3600         '第i个比较块,列值为1
        Do
            V = Cells(i + j + 1, 1)
            If V = "" Then Exit Do
                If V - t > 60 / 24 / 3600 Then
                 j = j + 1
                 Exit Do
                Else: End If
            j = j + 1
        Loop
        Cells(i, 3) = j             '结果放在第3列
    If V = "" Then
        Cells(i, 3) = j + 1       '最后一个块自动加1
        Exit Do
    Else: End If
        k = k + 1
        i = i + j                      '下一个块行值
    Loop
End Sub

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值