Beefy Boxes and Bandwidth Generously Provided by pair Networks
Pathologically Eclectic Rubbish Lister

Re^5: Perl r/w Excel with OLE

by davies (Parson)
on Jun 29, 2012 at 16:52 UTC ( #979152=note: print w/replies, xml ) Need Help??

in reply to Re^4: Perl r/w Excel with OLE
in thread Perl r/w Excel with OLE

Unless there's something going on that I don't understand (in which case I'd love to know), it won't work as you describe. Consider

# get a new workbook $book = $ex->Workbooks->Add;

This creates a new book, i.e. a new file, in the Excel instance. Then, when the code saves test.xls, it's only that book that gets saved. No sheets are added. $sheet is created by the line

$sheet = $book->Worksheets(1);

Again, this is in $book, not in anything that might have been open in the same instance. This can't fail, as the creation of $book will have the default number of sheets from SheetsInNewWorkbook, which can never be less than 1.

Now, I accept that the code given,

# save and exit $book->SaveAs( 'test.xls' ); undef $book; undef $ex;

doesn't actually close the instance of Excel, but merely undefines it in Perl. But this thread is, to a large extent, about closing instances of Excel, so my fear is undiminished.

If you don't have any instances of Excel open, there's no point even trying to take control of an open instance. And if you do, we return to the dangers on which we agree. If the code creates its own instance without trying to take control of an existing instance, you are safe either way.


John Davies

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://979152]
and all is quiet...

How do I use this? | Other CB clients
Other Users?
Others studying the Monastery: (5)
As of 2017-08-20 10:33 GMT
Find Nodes?
    Voting Booth?
    Who is your favorite scientist and why?

    Results (314 votes). Check out past polls.