Solved

Problem Automating Word 2007 -- ActiveDocument not found

Posted on 2008-10-17
7
1,157 Views
Last Modified: 2013-12-17
Hello Experts,

I have a asp.net page that creates and saves a .docx file to a directory and then uses word automation to open the docx and save it as a PDF file. I realize this isn't a great solution, but it's the only option I have at the moment. This works great on my dev box which is running Office 2007 sp1 on W2k3 Server. I was then asked to deploy this to a Win 2008 server. It also has Office 2007 sp1 installed.  

The problem:  Now the app runs and saves the docx file.  However, the word automation piece isn't working. I open the docx using this:
MSdoc.Documents.Open(ref Source, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown);

And then I save the file using this:
 MSdoc.ActiveDocument.SaveAs(ref Target, ref format,
                        ref Unknown, ref Unknown, ref Unknown,
                        ref Unknown, ref Unknown, ref Unknown,
                        ref Unknown, ref Unknown, ref Unknown,
                        ref Unknown, ref Unknown, ref Unknown,
                       ref Unknown, ref Unknown);

This last line triggers the error because it cannot find an Active Document.  Again, this works fine on my dev box.  I'm not sure what might be causing this.

Any help is much appreciated.
0
Comment
Question by:soapygus
  • 4
  • 3
7 Comments
 
LVL 13

Expert Comment

by:TechTiger007
ID: 22741731
Is the application opening a winword window for this document?
are you logged into the server when you tried  to run this application?
are you activating a document before saving?

I guess your answer would be yes for the above

You should not be opening a winword window or activate it because if you do so in the applicaiton it will fail if no user is logged in to the machine since the application will not create an active window on the server.

get the reference to the document and do what ever you want using the reference do not activate
0
 

Author Comment

by:soapygus
ID: 22743584

Thanks for the help. I'm not sure I understand what you mean by get a reference to the doc. Is it possible to save the document as a PDF using the techinique you describe?

Here is my method in full.

if (MSdoc == null) MSdoc = new Microsoft.Office.Interop.Word.ApplicationClass();

            try
            {
                MSdoc.Visible = true;
                MSdoc.Documents.Open(ref Source, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown);
                MSdoc.Application.Visible = true;
                MSdoc.WindowState = Microsoft.Office.Interop.Word.WdWindowState.wdWindowStateNormal;

                object format = Microsoft.Office.Interop.Word.WdSaveFormat.wdFormatPDF;

                MSdoc.ActiveDocument.SaveAs(ref Target, ref format,
                        ref Unknown, ref Unknown, ref Unknown,
                        ref Unknown, ref Unknown, ref Unknown,
                        ref Unknown, ref Unknown, ref Unknown,
                        ref Unknown, ref Unknown, ref Unknown,
                       ref Unknown, ref Unknown);
            }
            catch (Exception e)
            {
                return;
            }
            finally
            {
                if (MSdoc != null)
                {
                    MSdoc.Documents.Close(ref Unknown, ref Unknown, ref Unknown);
                    //WordDoc.Application.Quit(ref Unknown, ref Unknown, ref Unknown);
                }
                // for closing the application
                MSdoc.Quit(ref Unknown, ref Unknown, ref Unknown);
0
 
LVL 13

Expert Comment

by:TechTiger007
ID: 22743957
remove the following lines of code since we dont need the document to be opened in a window.

MSdoc.Visible = true;
                MSdoc.Application.Visible = true;
                MSdoc.WindowState = Microsoft.Office.Interop.Word.WdWindowState.wdWindowStateNormal;

also check if there is any Documents.Save method instead of ActiveDocuments.Save

0
Online Training Solution

Drastically shorten your training time with WalkMe's advanced online training solution that Guides your trainees to action. Forget about retraining and skyrocket knowledge retention rates.

 

Author Comment

by:soapygus
ID: 22744191

Ok --

I have updated the code to reference the doc as follows:

 if (wordApp == null) wordApp = new Microsoft.Office.Interop.Word.ApplicationClass();

            try
            {
                //Open the source docx
                wordDoc = wordApp.Documents.Open(
                     ref Source, ref Unknown, ref Unknown, ref Unknown, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown,
                     ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown,
                     ref Unknown);
               
                //Export docx to PDF
                if (wordDoc != null)
                {                
                    wordDoc.ExportAsFixedFormat(Target, paramExportFormat, paramOpenAfterExport,
                        paramExportOptimizeFor, paramExportRange, paramStartPage,
                        paramEndPage, paramExportItem, paramIncludeDocProps,
                        paramKeepIRM, paramCreateBookmarks, paramDocStructureTags,
                        paramBitmapMissingFonts, paramUseISO19005_1,
                        ref Unknown);
                }

            }

Unfortunately, ever time I step through the code the method exits at this line:
       
if (wordDoc != null)

I'm not sure why the wordDoc evaluates to null.  I've tried hard coding the path to the file, but I still get the same results.
0
 
LVL 13

Accepted Solution

by:
TechTiger007 earned 500 total points
ID: 22744545
Here is a simple example on opening and saving word document using C#
http://www.codeproject.com/KB/office/automate_word.aspx

Hope this would help you.
0
 

Author Comment

by:soapygus
ID: 22744619

Thanks you got me started in the right path.

I just created a new web app and used the exact same code and it worked.  I think I have a reference that is interfering, but I haven't found it yet.
0
 
LVL 13

Expert Comment

by:TechTiger007
ID: 22744741
you are welcome
0

Featured Post

PeopleSoft Has Never Been Easier

PeopleSoft Adoption Made Smooth & Simple!

On-The-Job Training Is made Intuitive & Easy With WalkMe's On-Screen Guidance Tool.  Claim Your Free WalkMe Account Now

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

It is often necessary in this forum and others to illustrate Word fields as text with the field delimiters replaced with the curly brackets that the delimiters resemble when field codes are being displayed on the document. This means that the text c…
Using Word 2013, I was experiencing some incredible lag when typing.  Here's what worked for me....
In this video, we show how to convert an image-only PDF file into a PDF Searchable Image file, that is, a file with both the image (typically from scanning) and text, which is created in an automated fashion with Optical Character Recognition (OCR) …
This video walks the viewer through the process of creating envelopes and labels, with multiple names and addresses. Navigate to the “Start Mail Merge” button in the Mailings tab: Follow the step-by-step process until asked to find the address doc…

730 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question