Tech Articles


Reading MS Outlook Items


Here is some code which reads data from Outlook (2007 was tested) into Powerbuilder. You basically need to create a window with a multiline edit and a button on it. Put this into the clicked event of the button.

To run it, open Outlook, select something (email message, task, etc.) then click the button on your PB window. There are many, many more methods and properties you have access to from PB via OLE to Outlook. The MSDN reference online is a big help

integer li_rc
long ll_itemcount, ll_i
oleobject lole_item, lole_outlook, lole_exp, lole_selecteditems
string ls_subject, ls_from, ls_to, ls_body, ls_msg
lole_outlook = CREATE oleobject
lole_exp = CREATE oleobject
lole_selecteditems = CREATE oleobject
li_rc = lole_outlook.ConnectToNewObject("outlook.application")
lole_exp = lole_outlook.ActiveExplorer()
// Outlook has to be running
If IsNull(lole_exp) THEN
    Messagebox('Outlook Error','Is Outlook currently running?')
    GOTO cleanup
END IF
li_rc = lole_exp.class
// caption is window name like "Inbox - Microsoft Outlook" or "Calendar - Microsoft Outlook"
ls_subject = lole_exp.caption

lole_selecteditems = lole_exp.selection
ll_itemcount = lole_selecteditems.count
FOR ll_i = 1 to ll_itemcount
    lole_item = CREATE oleobject
    lole_item = lole_exp.selection.item(ll_i)
    li_rc = lole_item.class
    CHOOSE CASE li_rc
        CASE 26 //appointment
            ls_body = lole_item.body
            ls_msg += '~r~n Appointment No: ' + string(ll_i) + ' of ' + string(ll_itemcount) + '~r~n' + ls_body
            // lots of other stuff could be here
        CASE 40 // contact
            ls_body = lole_item.body
            ls_msg += '~r~n Contact No: ' + string(ll_i) + ' of ' + string(ll_itemcount) + '~r~n' + ls_body
            
        CASE 43 // mail
            ls_subject = lole_item.subject
            ls_from = lole_item.sendername
            ls_to = lole_item.to
            ls_body = lole_item.body
            ls_msg = '~r~nSubject: ' + ls_subject + '~r~nFrom: ' + ls_from + '~r~nTo: ' + ls_to + '~r~nBody: ' + ls_body
            ls_msg += '~r~n Email No: ' + string(ll_i) + ' of ' + string(ll_itemcount) + '~r~n' + ls_msg
            
        CASE 48 // task
            ls_subject = lole_item.subject
            ls_to = lole_item.owner
            ls_body = lole_item.body
            ls_msg = '~r~nSubject: ' + ls_subject + '~r~nOwner: ' + ls_to + '~r~nBody: ' + ls_body
            ls_msg += '~r~n Task No: ' + string(ll_i) + ' of ' + string(ll_itemcount) + '~r~n' + ls_msg
            
    END CHOOSE
    DESTROY lole_item
NEXT
IF Len(ls_msg) > 0 THEN
    mle_1.text = ls_msg
ELSE
    mle_1.text = 'No items processed.'
END IF
cleanup:
DESTROY lole_selecteditems
DESTROY lole_exp
DESTROY lole_outlook
Comments (1)
Thursday, Apr 20 2017

If you also want to do anything that changes anything in more recent versions of Outlook (like create emails, as one of my programs does) you will run into the problem where Outlook prompts you to allow an external program to make changes, for X minutes. Very annoying. The solution is to use the Outlook Redemption object instead, from <a href="http://www.dimastr.com/redemption">http://www.dimastr.com/redemption.<;/a> It's a free library that duplicates most of the Outlook OLE API, but uses a lower-level API to do the actual work, eliminating that security prompt.

#3
0

Find Articles by Tag

File Array Event Handling Filter Transaction Outlook Web API PBNI RibbonBar Export JSON SDK Authentication JSON Repository Installation JSONGenerator Source Code Database Connection DLL iOS Event JSONParser Database Profile UI Themes Android NativePDF Import .NET Std Framework Service Windows 10 Icons SOAP Database Table Debugger SnapObjects CoderObject PowerBuilder Platform Database ActiveX 32-bit Design PowerBuilder Compiler Trial OLE Menu PowerServer Web IDE TreeView PowerBuilder (Appeon) RibbonBar Builder Windows OS Testing DataWindow Debugging Automated Testing PFC OrcaScript Graph Script Migration Mobile Data PDF MessageBox PowerScript (PS) Import JSON Sort DevOps SnapDevelop Event Handler WinAPI Performance DragDrop .NET DataStore Model XML Authorization COM CI/CD Application SQL Server Export GhostScript SQL PostgreSQL License Source Control Linux OS Deployment PBDOM BLOB CrypterObject InfoMaker Database Table Schema RESTClient PDFlib Open Source Class Excel Charts TortoiseGit Bug Interface TLS/SSL Resize Web Service Proxy OAuth Variable C# SVN Syntax Database Object Database Painter UI Modernization REST Messagging DataType Icon Stored Procedure Database Table Data PowerServer Mobile Text SqlExecutor External Functions PBVM HTTPClient Azure OAuth 2.0 API Encoding Visual Studio ODBC .NET Assembly Elevate Conference PostgreSQL ODBC driver Branch & Merge 64-bit UI RichTextEdit Control Configuration Error Expression Window Validation WebBrowser Git SqlModelMapper Jenkins Encryption TFS Oracle Debug DataWindow JSON