天天看點

幾個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