+ Reply to Thread
Results 1 to 6 of 6

UserForm Issue

Hybrid View

  1. #1
    Thomas
    Guest

    UserForm Issue

    Hi,

    I am opening an excel spreadsheet with a userform from another application
    (see code below) using late binding. I need to populate controls with data.
    How do I reference the userform?

    Set objExcel = CreateObject("Excel.Application")
    Set wbExcel = objExcel.Workbooks.Open("C:\test.xls")

    I tried wbExcel.UserForm11.TextBox1.Text and it does not work. Any ideas?

    Thanks



  2. #2
    Mark
    Guest

    Re: UserForm Issue


    I am not sure of the exact syntax, but I do know that the userform
    object IS NOT a member of excel. It is a member of the VBAProject
    Object. You might try using the Object Browser in the VBE to trace out
    the correct relationships.


  3. #3
    Tom Ogilvy
    Guest

    RE: UserForm Issue

    To show the userform, you have to run code contained in the workbook that
    contains the userform.

    You can have that code return a reference to the userform to your code and
    then use that to address the userform.

    --
    Regards,
    Tom Ogilvy




    "Thomas" wrote:

    > Hi,
    >
    > I am opening an excel spreadsheet with a userform from another application
    > (see code below) using late binding. I need to populate controls with data.
    > How do I reference the userform?
    >
    > Set objExcel = CreateObject("Excel.Application")
    > Set wbExcel = objExcel.Workbooks.Open("C:\test.xls")
    >
    > I tried wbExcel.UserForm11.TextBox1.Text and it does not work. Any ideas?
    >
    > Thanks
    >
    >
    >


  4. #4
    Tom Ogilvy
    Guest

    RE: UserForm Issue

    Just some added info:
    Here is some sample code from Rob Bovey:



    UserForms in an Excel project are private classes, so you can't call
    a UserForm in another project directly. What you can do is create a public
    function in the other project that returns an object reference to the
    UserForm. You will then be able to control the UserForm with this object
    reference from the outside project.


    For instance, if you have a UserForm named frmMyForm in the workbook
    Server.xls, you can add the following function to a regular module in that
    workbook to expose the UserForm


    Function ReturnForm() As frmMyForm
    Set ReturnForm = New frmMyForm
    End Function


    Then you can show this UserForm from a different procedure like so:


    Sub ShowForm()
    Dim objForm As Object
    Set objForm = Application.Run("Server.xls!ReturnForm")
    objForm.Show
    End Sub



    Rob Bovey

    --
    Regards,
    Tom Ogilvy


    "Thomas" wrote:

    > Hi,
    >
    > I am opening an excel spreadsheet with a userform from another application
    > (see code below) using late binding. I need to populate controls with data.
    > How do I reference the userform?
    >
    > Set objExcel = CreateObject("Excel.Application")
    > Set wbExcel = objExcel.Workbooks.Open("C:\test.xls")
    >
    > I tried wbExcel.UserForm11.TextBox1.Text and it does not work. Any ideas?
    >
    > Thanks
    >
    >
    >


  5. #5
    Thomas
    Guest

    Re: UserForm Issue

    Thanks for the post. After posting I figured out that I could build a
    public method in the workbook that I can pass data and that method interact
    with the userform.


    "Tom Ogilvy" <TomOgilvy@discussions.microsoft.com> wrote in message
    news:45EF0D0C-9582-409A-9786-7B07216F922A@microsoft.com...
    > Just some added info:
    > Here is some sample code from Rob Bovey:
    >
    >
    >
    > UserForms in an Excel project are private classes, so you can't call
    > a UserForm in another project directly. What you can do is create a public
    > function in the other project that returns an object reference to the
    > UserForm. You will then be able to control the UserForm with this object
    > reference from the outside project.
    >
    >
    > For instance, if you have a UserForm named frmMyForm in the workbook
    > Server.xls, you can add the following function to a regular module in that
    > workbook to expose the UserForm
    >
    >
    > Function ReturnForm() As frmMyForm
    > Set ReturnForm = New frmMyForm
    > End Function
    >
    >
    > Then you can show this UserForm from a different procedure like so:
    >
    >
    > Sub ShowForm()
    > Dim objForm As Object
    > Set objForm = Application.Run("Server.xls!ReturnForm")
    > objForm.Show
    > End Sub
    >
    >
    >
    > Rob Bovey
    >
    > --
    > Regards,
    > Tom Ogilvy
    >
    >
    > "Thomas" wrote:
    >
    >> Hi,
    >>
    >> I am opening an excel spreadsheet with a userform from another
    >> application
    >> (see code below) using late binding. I need to populate controls with
    >> data.
    >> How do I reference the userform?
    >>
    >> Set objExcel = CreateObject("Excel.Application")
    >> Set wbExcel = objExcel.Workbooks.Open("C:\test.xls")
    >>
    >> I tried wbExcel.UserForm11.TextBox1.Text and it does not work. Any
    >> ideas?
    >>
    >> Thanks
    >>
    >>
    >>




  6. #6
    Bob Phillips
    Guest

    Re: UserForm Issue

    Userforms are not part of any collection until they are loaded, so you need
    to load them then refence it.

    Load UserForm1

    UserForms.Item(0).TextBox1.Text = "ABC"

    --
    HTH

    Bob Phillips

    (replace somewhere in email address with gmail if mailing direct)

    "Thomas" <tom@ge.com> wrote in message
    news:%23Fm9HzHvGHA.2260@TK2MSFTNGP03.phx.gbl...
    > Hi,
    >
    > I am opening an excel spreadsheet with a userform from another application
    > (see code below) using late binding. I need to populate controls with

    data.
    > How do I reference the userform?
    >
    > Set objExcel = CreateObject("Excel.Application")
    > Set wbExcel = objExcel.Workbooks.Open("C:\test.xls")
    >
    > I tried wbExcel.UserForm11.TextBox1.Text and it does not work. Any ideas?
    >
    > Thanks
    >
    >




+ 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