The Quickbooks SDK has an excellent online reference manual for how to write custom programs to manipulate quickbooks. The manual links to a blog post demonstrating how to control quickbooks from Java. Below I post a Perl transliteration of the java code.
#!/usr/bin/perl use Data::Dumper; use IO::File; use XML::LibXML; use XML::LibXSLT; use Win32::OLE::Const; Win32::OLE->Option(Warn => 2); use strict; my $appname='Test App'; my $qbfile=''; main(); sub main { my $const = Win32::OLE::Const->Load("QBXMLRP2 1.0 Type Library"); my $session = Win32::OLE->new("QBFC10.QBSessionManager", sub {$_[0] +->CloseConnection();}) or die "oops\n"; $session->OpenConnection2("", $appname, $const->{"localQBD"}); my $ticket = $session->BeginSession($qbfile, $const->{"qbFileOpenDoN +otCare"}); my $msgSet = $session->CreateMsgSetRequest('US',3,0); $msgSet->AppendVendorQueryRq; my $resSet = $session->DoRequests($msgSet); my $resList = $resSet->ResponseList; my $count = $resList->Count; for (my $i=0; $i < $count; ++$i) { warn $i; my $res = $resList->GetAt($i); my $vendList = $res->Detail; warn Dumper($vendList); my $vcount = $vendList->Count; for (my $j=0; $j < $vcount; ++$j) { my $vend = $vendList->GetAt($j); my $dname = $vend->Name; my $name = $dname->GetValue; warn "Vendor name: $name"; } } $session->EndSession; $session->CloseConnection; warn "Goodbye World!"; }




The mantra of every experienced web application developer is the same: thou shalt separate business logic from display. Ironically, almost all template engines allow violation of this separation principle, which is the very impetus for HTML template engine development.

-- Terence Parr, "Enforcing Strict Model View Separation in Template Engines"


In reply to Control Windows Quickbooks with Win32::OLE by metaperl

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.