+ Reply to Thread
Results 1 to 6 of 6

Calling Private Sub/Function

Hybrid View

  1. #1
    Registered User
    Join Date
    01-28-2005
    Posts
    70

    Calling Private Sub/Function

    So how can you call a Private Sub or Function? Or is that simply not possible? I have an OnTime event that needs to call another Sub when the timer runs out, but that other Sub is private.

    Edited to add: I meant calling from a different module or userform. I know I can call from within the same module, but this is a Userform trying to call a Private Sub... Any way of making that work?
    Last edited by AMK4; 02-03-2006 at 07:46 PM.

  2. #2
    Norman Jones
    Guest

    Re: Calling Private Sub/Function

    Hi AMK4

    Look at the Run method in VBA help.


    ---
    Regards,
    Norman



    "AMK4" <AMK4.22og4m_1139010001.6889@excelforum-nospam.com> wrote in message
    news:AMK4.22og4m_1139010001.6889@excelforum-nospam.com...
    >
    > So how can you call a Private Sub or Function? Or is that simply not
    > possible? I have an OnTime event that needs to call another Sub when
    > the timer runs out, but that other Sub is private.
    >
    >
    > --
    > AMK4
    > ------------------------------------------------------------------------
    > AMK4's Profile:
    > http://www.excelforum.com/member.php...o&userid=19143
    > View this thread: http://www.excelforum.com/showthread...hreadid=508329
    >




  3. #3
    Registered User
    Join Date
    01-28-2005
    Posts
    70
    Quote Originally Posted by Norman Jones
    Hi AMK4

    Look at the Run method in VBA help.
    I'm a bit confused. How would I use this in an OnTime method?

    This is what I'm trying to get to:

    My userForm has this on it:
    Application.OnTime Now + TimeValue("00:00:05"), "myMacro"

    myMacro is a Private Sub defined in the Modules. How would I use Application.Run instead of calling myMacro?

  4. #4
    Norman Jones
    Guest

    Re: Calling Private Sub/Function

    Hi AMK4,

    One way:

    Sub AAA()
    Application.OnTime Now + TimeValue("00:00:05"), "myMacro"
    End Sub

    Sub myMacro()
    Call BBB
    End Sub

    Private Sub BBB()
    MsgBox "Hello"
    End Sub


    ---
    Regards,
    Norman



    "AMK4" <AMK4.22ohim_1139011802.0531@excelforum-nospam.com> wrote in message
    news:AMK4.22ohim_1139011802.0531@excelforum-nospam.com...
    >
    > Norman Jones Wrote:
    >> Hi AMK4
    >>
    >> Look at the Run method in VBA help.

    >
    > I'm a bit confused. How would I use this in an OnTime method?
    >
    > This is what I'm trying to get to:
    >
    > My userForm has this on it:
    > Application.OnTime Now + TimeValue("00:00:05"), "myMacro"
    >
    > myMacro is a Private Sub defined in the Modules. How would I use
    > Application.Run instead of calling myMacro?
    >
    >
    > --
    > AMK4
    > ------------------------------------------------------------------------
    > AMK4's Profile:
    > http://www.excelforum.com/member.php...o&userid=19143
    > View this thread: http://www.excelforum.com/showthread...hreadid=508329
    >




  5. #5
    Norman Jones
    Guest

    Re: Calling Private Sub/Function

    Hi AMK4,

    In fact, if no parameters are to be passed, the private macro or function
    can be called without recourse to the Run method:

    Sub AAA()
    Application.OnTime Now + TimeValue("00:00:05"),"MyMacro"
    End Sub

    Or, if the macro is in another workbook:

    Sub AAAA()
    Application.OnTime Now + TimeValue("00:00:05"), _
    "'Another Workbook'!MyMacro"
    End Sub

    Or, if the macro is in a sheet module of another workbook:

    Sub AAAAA()
    Application.OnTime Now + TimeValue("00:00:05"), _
    "'Another Workbook'!Sheet1.MyMacro"
    End Sub


    ---
    Regards,
    Norman


    "AMK4" <AMK4.22ohim_1139011802.0531@excelforum-nospam.com> wrote in message
    news:AMK4.22ohim_1139011802.0531@excelforum-nospam.com...
    >
    > Norman Jones Wrote:
    >> Hi AMK4
    >>
    >> Look at the Run method in VBA help.

    >
    > I'm a bit confused. How would I use this in an OnTime method?
    >
    > This is what I'm trying to get to:
    >
    > My userForm has this on it:
    > Application.OnTime Now + TimeValue("00:00:05"), "myMacro"
    >
    > myMacro is a Private Sub defined in the Modules. How would I use
    > Application.Run instead of calling myMacro?
    >
    >
    > --
    > AMK4
    > ------------------------------------------------------------------------
    > AMK4's Profile:
    > http://www.excelforum.com/member.php...o&userid=19143
    > View this thread: http://www.excelforum.com/showthread...hreadid=508329
    >




  6. #6
    Norman Jones
    Guest

    Re: Calling Private Sub/Function

    Hi AMK4,

    And, if parameters are to be passed to the function or macro, then try
    something like:

    Sub ABC()
    Application.OnTime Now + TimeValue("00:00:05"), "BBB"
    End Sub

    Sub BBB()
    MsgBox Application.Run("MyFunction", 2, 3)
    End Sub

    Private Function MyFunction(var1, var2)
    MyFunction = var1 * var2
    End Function


    ---
    Regards,
    Norman



+ Reply to Thread

Thread Information

Users Browsing this Thread

There are currently 1 users browsing this thread. (0 members and 1 guests)

Bookmarks

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts

Search Engine Friendly URLs by vBSEO 3.6.0 RC 1