DOCUMENT:Q269617 25-SEP-2001 [foxpro] TITLE :HOWTO: Automatically Add Contacts to Outlook PRODUCT :Microsoft FoxPro PROD/VER::6.0 OPER/SYS: KEYWORDS:kbAutomation kbOutlook kbvfp600 kbGrpDSFox kbDSupport kbOutlook2000 kbCodeSnippet ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - Microsoft Visual FoxPro for Windows, version 6.0, used with: - Microsoft Outlook 2000 ------------------------------------------------------------------------------- SUMMARY ======= Microsoft Outlook is an Automation Server. As such, you can programatically control it from other applications, sending data back and forth. MORE INFORMATION ================ The following example demonstrates how to import the Tasmanian Traders sample's Customer table into Outlook's Contacts folder. NOTE: The following example was written for use with Microsoft Visual FoxPro version 6.0. #DEFINE olFolderContacts 10 #DEFINE olCurrency 14 #DEFINE olPercent 12 LOCAL loOutlook, loNameSpace, loFolder, loContact, loNewContact CLOSE DATA ALL USE HOME(2) + "TasTrade\data\customer" *!* Get an object reference to Outlook loOutlook = CREATE("Outlook.Application") *!* Get the MAPI namespace (the only available one) *!* and find the Contacts folder loNamespace = loOutlook.GetNameSpace("MAPI") loFolder = loNameSpace.GetDefaultFolder(olFolderContacts) *!* Add a subfolder below the standard Contacts folder loContact = loFolder.folders.Add("Tasmanian Traders") SCAN loNewContact = loContact.Items.Add() && Returns an object of type && ContactItem WITH loNewContact .FullName = contact_name .JobTitle = contact_title .CompanyName = company_name *!* This makes the company name appear above the contact name in *!* Outlook. It will also sort by company name. .FileAs = .CompanyName + " (" + ; ALLTRIM(.LastName + ", " + .FirstName + " " + .MiddleName) + ")" *!* Unfortunately, the Contacts table does not include email. *!* Note: the property below is Email One Address. This is not clear *!* under some fonts. .Email1Address = "random@nospam.com" .Email1AddressType = "SMTP" lcAddress = ALLTRIM(address) + CHR(10) + ; ALLTRIM(city) + ; IIF(EMPTY(region), "", ", " + ALLTRIM(region)) + " " + ; ALLTRIM(postal_code) + ; IIF(country != "USA", CHR(10) + ALLTRIM(country), "") .HomeAddress = lcAddress .BusinessTelephoneNumber = ALLTRIM(phone) .BusinessFaxNumber = ALLTRIM(fax) *!* Create user-defined properties for extra fields .UserProperties.Add("Max Order Amount", olCurrency) .UserProperties.Add("Min Order Amount", olCurrency) .UserProperties.Add("Discount", olPercent) *!* If you use numeric indexes here (1, 2, and 3) you'll *!* find that the collection is alphabetical. .UserProperties("Discount").Value = ROUND(discount / 100, 2) .UserProperties("Max Order Amount").Value = max_order_amt .UserProperties("Min Order Amount").Value = min_order_amt *!* ContactItem does not appear in Outlook until it is saved. .Save ENDwith ENDscan CLOSE DATA ALL After the preceding code is run, do the following to view the results: 1. Open Microsoft Outlook and navigate to the Contacts\Tasmanian Traders folder. 2. Double-click a contact to open it. Under the General tab, note that all the fields for each contact, except for the three user-defined fields, are visible. 3. Select the All Fields tab to view the user-defined fields. For similar code in Microsoft Access, click the article number below to view the article in the Microsoft Knowledge Base: Q290792 OL2002: How to Programmatically Export Outlook Items to Microsoft Access REFERENCES ========== For additional information about Outlook Automation, click the article number below to view the article in the Microsoft Knowledge Base: Q222101 HOWTO: Find and Use Office Object Model Documentation For detailed Help information about the various ContactItem fields and other Outlook objects, see the MSDN Library under Office Developer Documentation:Microsoft Office 2000 Language Reference:Microsoft Outlook 2000 Reference. (c) Microsoft Corporation 2000, All Rights Reserved. Contributions by Garrett Fitzgerald, Microsoft Corporation Additional query words: ====================================================================== Keywords : kbAutomation kbOutlook kbvfp600 kbGrpDSFox kbDSupport kbOutlook2000 kbCodeSnippet Technology : kbVFPsearch kbAudDeveloper Version : :6.0 Issue type : kbhowto ============================================================================= THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY. Copyright Microsoft Corporation 2001.