http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnoffdev/html/vsofficedev.asp
How do I automate a Microsoft Office application from Visual C++?
There are several ways you can control Office applications through automation using Visual C++:
For more details, see INFO: Using Visual C++ to Automate Office (Q238972).
How do I attach to the running instance of an Office application?
To automate an Office application that is already running, you can use the GetActiveObject() API function to obtain the IDispatch pointer. Once you have the IDispatch pointer for the running instance, you can then call its methods and properties. For additional information, see HOWTO: Attach to a Running Instance of an Office Application (Q238975).
How do I pass optional parameters to methods and properties?
When you call a method that has optional parameters from Visual C++, you cannot omit the optional parameters. Instead, if the parameter type is a VARIANT, you can pass a special variant for arguments you intend to omit. This VARIANT has the type VT_ERROR and a code member of DISP_E_PARAMNOTFOUND. For more details, see HOWTO: Passing Optional Parameters When Calling a Function (Q238981).
How do I pass a COleDispatchDriver as an argument for a method expecting a VARIANT?
Some methods require that you pass a VARIANT that represents an Automation object. With MFC, these objects are typically handled by COleDispatchDriver-derived classes. To pass one of these to a method expecting a VARIANT, you can create a new VARIANT with its vt member set to VT_DISPATCH and its pdispVal member set to the COleDispatchDriver class' m_lpDispatch. For more details and a sample, please see HOWTO: Pass a COleDispatchDriver as an Argument for a Method Expecting a VARIANT (Q253501).
How do I catch events?
Automation objects that can raise events implement a connection point interface. Automation controllers can create "sinks" to "connect" with an Automation object's connection point so that it receives event notifications. Note that MFC's default implementation of IDispatch::Invoke does not support named arguments. Therefore, with some Automation servers—Microsoft Excel, for example—you must provide your own implementation of IDispatch in the sink. For examples, see HOWTO: Catch Microsoft Word97 Application Events Using VC++ (Q183599) and HOWTO: Catch Microsoft Excel Application Events Using VC++ (Q186427).
How do I improve the performance of my automation code?
You can improve the performance of your Automation code in Visual C++ by using a two-dimensional variant SAFEARRAY to read and write data all at once, and then using the clipboard to copy and paste data. For additional information, see HOWTO: Improving the Performance of Office Automation Code (Q238984).
What do these huge error values, such as -2147352573 or 0x80030002, mean?
While automating an Office application, you might receive a large error value, such as -2147221494. Troubleshooting the error is greatly facilitated by determining the exact description of the error. To obtain a description of the error, you can use the Error Lookup utility provided with Visual C++, call the FormatMessage() API at run-time, or use the watch window to display the error message. These approaches are described in INFO: Translating Large Office Automation Error Values (Q238986).
The application I'm automating stays in memory after my program is finished. What's happening?
If the Office application you are automating continues to reside in memory after your Visual C++ program finishes executing, the most likely cause is that you have not released an acquired interface. For more information, see PRB: Office Application Remains in Memory After Program Finishes (Q238987)
How do I access my document properties in an Office document?
You can automate Microsoft Word, Excel or PowerPoint with Visual C++ to retrieve and manipulate both built-in and custom document properties. For more information and an example, see HOWTO: Use Visual C++ to Access DocumentProperties with Automation (Q238393).
You can also retrieve document property information without Automation and even without the need for the Office application that created the file. Office documents are OLE compound documents that store document properties in persistent property sets. These property sets are managed by COM/OLE and can be retrieved using the IPropertySetStorage and IPropertyStorage interfaces. For details, see HOWTO: Read Compound Document Properties Directly with VC++ (Q186898) and Dsofile.exe Lets You Edit Office Document Properties from Visual Basic and Active Server Pages (Q224351).
How can I automate an embedded Microsoft Office document?
To automate an embedded Office document, you must first obtain the IDispatch pointer for the document object. Once you've obtained the IDispatch pointer to the document object, you can automate the server by calling the appropriate methods and properties for that server. For some examples, see HOWTO: Embed and Automate a Microsoft Excel Worksheet with MFC (Q184663) and HOWTO: Embed and Automate a Word Document with MFC (Q238611).
My Automation client for an Office application runs without error except when I run my client from an NT service.
Microsoft Office is designed for use on client systems as end-user products and has not been optimized to run from Windows NT Services. Automating an Office application from a service is not recommended or supported. For details on problems that you might encounter automating an Office application from a service and common causes of those problems, please see INFO: Considerations for Server-Side Automation of Office (Q257757).
This section contains information and links to code samples for Office Automation using Visual C++ and MFC. Any one of the articles listed below may illustrate Automation with a specific version of Microsoft Office. In most cases, you can follow the step-by-step instructions in the article and run the sample without needing to modify the code. However, if you are using one of the code samples created with a version of Office earlier than the one you are automating, you may need to modify the code to account for new arguments of updated methods. For more information, see the Knowledge Base article Type Libraries for Office May Change with New Release (Q224925).
General Concepts
Create Automation Project Using MFC and a Type Library (Q178749)
Locating Resources to Study Automation (Q152023)
Find the Path and Version of an Office Application from Visual C++ (Q247985)
Use OLE Automation from a C Application Rather Than C++ (Q181473)
Create an Automation Client Project Using ATL (Q196135)
Do 16-Bit Automation in C++ Using VC 1.52 (Q194656)
OLE/COM Concepts
Descriptions and Workings of OLE Threading Models (Q150777)
OLE Threads Must Dispatch Messages (Q136885)
MARSHAL.EXE: How To Marshal Interfaces Across Apartments (Q206076)
COM Security Frequently Asked Questions (Q158508)
TN039: MFC/OLE Automation Implementation (MFC Technical Note)
Microsoft Excel Automation
Use MFC to Automate Excel and Create/Format a New Workbook (Q179706)
Embed and Automate a Microsoft Excel Worksheet with MFC (Q184663)
Use MFC to Automate Excel and Fill a Range with an Array (Q186120)
Use MFC to Automate Excel and Obtain an Array from a Range (Q186122)
Automate Excel Using MFC and Worksheet Functions (Q178781)
Use MFC to Copy a DAO Recordset to Excel With Automation (Q243394)
Use MFC to Create a Microsoft Excel Chart (Q178783)
Catch Microsoft Excel Application Events Using VC++ (Q186427)
Automate Excel and Then Know the User Closed It (Q192348)
Use MFC to Automate Excel and Navigate Worksheets (Q178782)
Automate Using VC++ to Save Excel Worksheet as HTML File (Q199691)
Convert Indices (row,col) into Excel-Style A1:C1 Strings (Q198112)
Automate Excel From C++ Without Using MFC or #import (Q216686)
COMEXCEL: Demonstrates an Automation Client Application with Compiler COM Support