PC Review


Reply
Thread Tools Rate Thread

Calling an Excel function from Delphi w/ OLE

 
 
Tom
Guest
Posts: n/a
 
      21st Nov 2007
Can anyone tell me how I can call an Excel function via OLE automation.

var
xlApp: Variant;

xlApp := CreateOLEObject('Excel.Application');

I know this line will run a macro:

xlApp.Run( 'WorkBookName.xls!Macro1');

Is there a similar line that will call an Excel VBA function, returning the
results?

TIA.

 
Reply With Quote
 
 
 
 
Jialiang Ge [MSFT]
Guest
Posts: n/a
 
      22nd Nov 2007
Hello,

From your post, my understanding on this issue is: you wonder whether it is
possible to run VBA function via OLE automation . If I'm off base, please
feel free to let me know.

The method 'Run' can only accept macro name and arguments as its
parameters. If we call the VBA functions, it will throw an exception: "The
macro '*****' cannot be found."

If your "VBA function" refers to the VBA built-in functions like "MsgBox",
there does not exist a direct method to call them. A possible workaround is
to dynamically create a macro that wrap the VBA function (see:
http://support.microsoft.com/kb/303871/), then call the macro with the Run
method.

If your "VBA function" refers to the Excel object model, we could call the
object model directly on the xlApp object. For example (in VB):
Dim oExcel As Object
'Start Excel and open the workbook.
oExcel = CreateObject("Excel.Application")
oExcel.Visible = True
oExcel.Workbooks.Add() ' call the excel object model

Please let me know if you have any other concerns, or need anything else.

Sincerely,
Jialiang Ge ((E-Mail Removed), remove 'online.')
Microsoft Online Community Support

==================================================
For MSDN subscribers whose posts are left unanswered, please check this
document: http://blogs.msdn.com/msdnts/pages/postingAlias.aspx

Get notification to my posts through email? Please refer to
http://msdn.microsoft.com/subscripti...ult.aspx#notif
ications. If you are using Outlook Express/Windows Mail, please make sure
you clear the check box "Tools/Options/Read: Get 300 headers at a time" to
see your reply promptly.

Note: The MSDN Managed Newsgroup support offering is for non-urgent issues
where an initial response from the community or a Microsoft Support
Engineer within 1 business day is acceptable. Please note that each follow
up response may take approximately 2 business days as the support
professional working with you may need further investigation to reach the
most efficient resolution. The offering is not appropriate for situations
that require urgent, real-time or phone-based interactions or complex
project analysis and dump analysis issues. Issues of this nature are best
handled working with a dedicated Microsoft Support Engineer by contacting
Microsoft Customer Support Services (CSS) at
http://msdn.microsoft.com/subscripti...t/default.aspx.
==================================================
This posting is provided "AS IS" with no warranties, and confers no rights.

 
Reply With Quote
 
Tom
Guest
Posts: n/a
 
      22nd Nov 2007
Actually, I want to call a function that is not part of the VBA object
model. This is a function that I created in a workbook in VBA.

Is it possible to call that?

Thank you, Jialiang, for your help.

Tom


"Jialiang Ge [MSFT]" <(E-Mail Removed)> wrote in message
news:Bsz$(E-Mail Removed)...
> Hello,
>
> From your post, my understanding on this issue is: you wonder whether it
> is
> possible to run VBA function via OLE automation . If I'm off base, please
> feel free to let me know.
>
> The method 'Run' can only accept macro name and arguments as its
> parameters. If we call the VBA functions, it will throw an exception: "The
> macro '*****' cannot be found."
>
> If your "VBA function" refers to the VBA built-in functions like "MsgBox",
> there does not exist a direct method to call them. A possible workaround
> is
> to dynamically create a macro that wrap the VBA function (see:
> http://support.microsoft.com/kb/303871/), then call the macro with the Run
> method.
>
> If your "VBA function" refers to the Excel object model, we could call the
> object model directly on the xlApp object. For example (in VB):
> Dim oExcel As Object
> 'Start Excel and open the workbook.
> oExcel = CreateObject("Excel.Application")
> oExcel.Visible = True
> oExcel.Workbooks.Add() ' call the excel object model
>
> Please let me know if you have any other concerns, or need anything else.
>
> Sincerely,
> Jialiang Ge ((E-Mail Removed), remove 'online.')
> Microsoft Online Community Support
>
> ==================================================
> For MSDN subscribers whose posts are left unanswered, please check this
> document: http://blogs.msdn.com/msdnts/pages/postingAlias.aspx
>
> Get notification to my posts through email? Please refer to
> http://msdn.microsoft.com/subscripti...ult.aspx#notif
> ications. If you are using Outlook Express/Windows Mail, please make sure
> you clear the check box "Tools/Options/Read: Get 300 headers at a time" to
> see your reply promptly.
>
> Note: The MSDN Managed Newsgroup support offering is for non-urgent issues
> where an initial response from the community or a Microsoft Support
> Engineer within 1 business day is acceptable. Please note that each follow
> up response may take approximately 2 business days as the support
> professional working with you may need further investigation to reach the
> most efficient resolution. The offering is not appropriate for situations
> that require urgent, real-time or phone-based interactions or complex
> project analysis and dump analysis issues. Issues of this nature are best
> handled working with a dedicated Microsoft Support Engineer by contacting
> Microsoft Customer Support Services (CSS) at
> http://msdn.microsoft.com/subscripti...t/default.aspx.
> ==================================================
> This posting is provided "AS IS" with no warranties, and confers no
> rights.
>


 
Reply With Quote
 
Jialiang Ge [MSFT]
Guest
Posts: n/a
 
      23rd Nov 2007
Hello,

According to your description, do you mean the user defined function (UDF)?
For instance, a function defined in a module like:

Function Test()
Test = "aaa"
End Function

The method Run is able to call the function in a excel workbook. The return
value of the function will be the return value of Run. For instance:

Dim oExcel As Object
'Start Excel and open the workbook.
oExcel = CreateObject("Excel.Application")
oExcel.Visible = True
oExcel.Workbooks.Open("d:\book1.xls")
Console.Write(oExcel.Run("Book1.xls!Test"))

The VB.NET code above will call the function Test. Console.Write will
output "aaa" in console.

If you have any other question, or need anything else, please feel free to
let me know.

Sincerely,
Jialiang Ge ((E-Mail Removed), remove 'online.')
Microsoft Online Community Support

=================================================
When responding to posts, please "Reply to Group" via your newsreader
so that others may learn and benefit from your issue.
=================================================
This posting is provided "AS IS" with no warranties, and confers no rights.


 
Reply With Quote
 
Jialiang Ge [MSFT]
Guest
Posts: n/a
 
      27th Nov 2007
Hi,

Would you mind letting me know the result of the suggestions? If you need
further assistance, feel free to let me know. I will be more than happy to
be of assistance.

Have a great day!

Sincerely,
Jialiang Ge ((E-Mail Removed), remove 'online.')
Microsoft Online Community Support

=================================================
When responding to posts, please "Reply to Group" via your newsreader
so that others may learn and benefit from your issue.
=================================================
This posting is provided "AS IS" with no warranties, and confers no rights.

 
Reply With Quote
 
 
 
Reply

Thread Tools
Rate This Thread
Rate This Thread:

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are Off


Similar Threads
Thread Thread Starter Forum Replies Last Post
Calling Delphi DLL from C# not passing integer correctly. silentbazz@googlemail.com Microsoft C# .NET 3 26th Nov 2008 08:02 PM
Calling a Delphi DLL kelvin.koogan@googlemail.com Microsoft VC .NET 5 1st Aug 2008 09:49 PM
Calling Delphi code from C# jewalsh2k@gmail.com Microsoft C# .NET 2 4th Jun 2006 05:39 AM
[Excel][DLL] Writing a DLL custom function for Excel with Delphi =?iso-8859-1?Q?St=E9phane?= Santon Microsoft Excel Programming 0 18th Jul 2004 09:35 PM
Calling VB.Net Class File from Delphi Three Microsoft VB .NET 5 2nd Apr 2004 12:38 AM


Features
 

Advertising
 

Newsgroups
 


All times are GMT +1. The time now is 09:15 PM.