Use Microsoft Word documentation in ASP.NET

zhaozj2021-02-16  55

Use Microsoft Word documentation in ASP.NET

[Source] http://www.codeproject.com/UserItems/WordApplication.asp

[Author] michela

[Download the demo project used in this article] Project file size: 309 kB

[Introduction]

This article is written in the ASP.NET to create a Microsoft Word document. This article demonstrates how to create and modify Microsoft Word documents in ASP.NET.

[background]

Automation is an (e.g.,: Visual Basic.NET or C #) application written in various languages ​​to control other applications at the program level. For Word's automation allows you to perform such a new document, add text, mail merge, and formatted documents to your document. In Word and other Microsoft Office programs, those visual operations performed through the user interface can also be implemented by automation of the program level. Word provides an interface with an object-operable functionality through an object model. The object model is a set of sets and methods, these classes and methods correspond to the logical components of Word. For example, he might be an application object, a document object, a paragraph object, and each object contains the functionality of the Word component.

[Establishment Project]

The first step in the .NET operates is to add a COM reference to your project, click Right click on the Solution Explorer's Reference, Add Reference. Select the COM tab and find Microsoft Word 10.0 Object Library. Click to select, OK. This will automatically add an assembly package with Word's COM to the application directory. Now you can build a Word instance:

Word.ApplicationClass OwordApp = New Word.ApplicationClass ();

You can call Word to provide you with the method and properties to manipulate the Word document. Learning how to use Word, Excel, PowerPoint's object model is the use of Macro Recorder in these Office applications:

1. Select Record New Macro in the Macro option in the Tools menu and perform tasks you are interested. 2. Select Stop Recording in the Macro option of the Tools menu. 3. If you have a record, select the macros in the macro option in the Tools menu, find the macro you record, you can edit it.

The above operation produces VBA code to complete the task you record. It should be noted that macros is not the best code in most cases, but it provides a convenient and available approach. The following example opens and adds a writing text:

object fileName = "c: //database//test.doc"; object readOnly = false; object isVisible = true; object missing = System.Reflection.Missing.Value; Word.ApplicationClass oWordApp = new Word.ApplicationClass (); Word .Document oWordDoc = oWordApp.Documents.Open (ref fileName, ref missing, ref readOnly, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref isVisible, ref missing, ref Missing, ref missiVate (); owordapp.selection.typetext ("this is the text"); OWORDAPP.SELECTION.TYPEPARAGRAGRAPH () ;OWORDDOC.SAVE (); OWORDAPP.Application.quit (Ref missing, ref MISSING, REF MISSING; if you create a new document and save this:

Word.ApplicationClass oWordApp = new Word.ApplicationClass (); Word.Document oWordDoc = oWordApp.Documents.Add (ref missing, ref missing, ref missing, ref missing); oWordDoc.Activate (); oWordApp.Selection.TypeText ( "This Is the text "); OWORDAPP.SELECTION.TYPEPARAGRAPH (); OWORDDOC.SAVEAS (" c: //myfile.doc "); OWordApp.Application.quit (Ref missing, ref missing, ref missing);

In C #, the Word document class open method is defined: Open (Ref Object, Ref Object, Ref Object, Ref Object, Ref Object, Ref Object, Ref Object, REF Object, Ref Object, Ref Object, Ref Object, Ref Object, Ref Object, REF Object, Ref Object. 15 parameters are required in the open method in the C #, and each parameter must be described by the REF keyword, and is the object type. The first parameter is the file, name, usually a string in Visual Basic.NET, but in C #, it must be an object containing String, the code is like this:

Object filename = "c: //database/test.doc";

Although we only need to use the first parameter of the Open method, C # does not allow the default parameters to be used, so we give it 14 Object types: system.reflection.Missing.Value

[Use "

If you need to automatically build a document with universal format, you can use pre-formatted tatto to create new documents, which can be much convenient. There are two obvious advantages that use taps in Word rather than establish empty documents: 1. You can format the document and control documentation in a greater extent. 2. Can establish a document with less code.

By using the touch version, you can adjust the table, paragraphs, and some other locations in the document, while including formatting these objects. By using an automation process, you can create a touch-based document, the code is as follows:

Word.ApplicationClass oWordApp = new Word.ApplicationClass (); object oTemplate = "c: //MyTemplate.dot"; oWordDoc = oWordApp.Documents.Add (ref oTemplate, ref Missing, ref Missing, ref Missing);

In your tatting you use, you can define some marks and automation will populate the text to these locations, as follows:

Object Obookmark = "MyBookmark"; OWORDDOC.BOOKMARKS.ITEM (Ref Obookmark) .Range.Text = "Some Text Here";

Another advantage of using the touch is that you can create and save those formatted patterns you want during the running process, as follows:

Object ostylename = "mystyle"; OwordDoc.bookmarks.Item (Ref Obookmark) .Range.set_style (Ref OstyleName);

[Use ccWordApp class]

In the project contains ccWordapp.cs file, I don't want to always write the text, open the code like this. So, I decided to package some of the most important features into the ccWordApp class. The following code briefly describes this class and his features:

public class CCWordApp {// it's a reference to the COM object of Microsoft Word Application private Word.ApplicationClass oWordApplic; // it's a reference to the document in use private Word.Document oWordDoc; // Activate the interface with the COM object of Microsoft Word public CCWordApp (); // Open an existing file or open a new file based on a template public void Open (string strFileName); // Open a new document public void Open (); // Deactivate the interface with the COM object of Microsoft Word public void Quit (); // Save the document public void Save (); // Save the document with a new name as HTML document public void SaveAs (string strFileName); // Save the document in HTML format public void SaveAsHtml (string strFileName); // Insert Text public void InsertText (string strText); // Insert Line Break public void InsertLineBreak (); // Insert multiple Line Break public void InsertLineBreak (int NLINE); // set the paragraph alignment // Possible Values ​​of Strtype: "Centre", "Right", "Left", "Justify" public void setAlignment (String start "; // set the font style // Possible Values ​​of Strtype: "Bold", "Italic" "underlined" public void setfont (string strading); // disable all the style public void setfont (); // set the font name public void setfontname (string strading); // set the Font Dimension Public Void SetFontSIZE (int nsize); // INSERT A page break public void insertpagebreak (); // Go to a predefined Bookmark Public Void gotobookmark (String StrBookmarkname);

// go to the end of document public void gotothend (); // go to the beginning of document public void gotothebeginning (); Open an existing file will be like this:

CcWordApp test; test = new ccWordApp (); test.open ("c: //database/test.doc"); test.inserttext ("this is the text"); test.insertlinebreak; test.save (); test.save (); Test.quit ();

[detail]

The demo project includes: ccWordapp.cs - class CreatedOCModel.aspx used above - a new document based on the bookmark's touch version. CreateNewDoc.aspx - Create a new document and add a write text. ModifyDocument.aspx - Open an existing document and add some text at the end. Template / Template1.dot - Example of Tsing Edition (used in CreatedOCModel.aspx)

Note that you are used to save the documentation, which should be rewritten. You can modify this path in Web.config.

[references]

Microsoft Word Objects Converting Microsoft Office VBA Macros to Visual Basic .NET and C # HOWTO: Automate Microsoft Word to Perform a Mail Merge from Visual Basic .NET A Primer to the Office XP Primary Interop Assemblies HOWTO: Find and Use Office Object Model Documentation Creating and Opening Microsoft Word Documents from .NET USING C #

转载请注明原文地址:https://www.9cbs.com/read-23063.html

New Post(0)