--
Mở một tài liệu Word bằng C#
Bài này tôi sẽ hướng dẫn cách sử dụng các tham số được dùng trong việc mở một tài liệu Word hay file nào đó dưới ứng dụng MS Word bằng C#.
Chúng ta hãy cùng xem xét một ví dụ:
- private void btnGetWordDocument_Click(object sender, EventArgs e)
- {
- // Tạo một thể hiện của ứng dụng MS Word
- ApplicationClass wordApp = new ApplicationClass();
- // Các tham số được sử dụng trong hàm Open được hỗ trợ bởi thư viện API của MS Word
- object wFileName = System.IO.Directory.GetCurrentDirectory() + "\\demoMSWordAPI.suo";
- object wConfirmConversions = true;
- object wReadOnly = true;
- object wAddToRecentFiles = true;
- object wPasswordDocument = "norikosaika";
- object wPasswordTemplate = "";
- object wRevert = true;
- object wWritePasswordDocument = "";
- object wWritePasswordTemplate = "";
- object wFormat = WdOpenFormat.wdOpenFormatAuto;
- object wEncoding = Microsoft.Office.Core.MsoEncoding.msoEncodingAutoDetect;
- object wVisible = true;
- object wOpenAndRepair = true;
- object wDocumentDirection = WdDocumentDirection.wdRightToLeft;
- object wNoEncodingDialog = false;
- object wXMLTransform = Missing.Value;
- // Nếu bạn không sử dụng thông số nào đó trong hàm Open thì sử dụng biến này
- // với giá trị missing value để truyền vào cho đúng profile của hàm
- object nullobj = System.Reflection.Missing.Value;
- // Show cửa sổ ứng dụng Word
- wordApp.Visible = true;
-
- // Solution 1: không sử dụng các thông số không cần thiết ngoai trừ đường dẫn đến file cần mở
- //Document doc = wordApp.Documents.Open(
- // ref wFileName, ref nullobj, ref nullobj, ref nullobj,
- // ref nullobj, ref nullobj, ref nullobj, ref nullobj,
- // ref nullobj, ref nullobj, ref nullobj, ref nullobj,
- // ref nullobj, ref nullobj, ref nullobj, ref nullobj);
- // Solution 2: Sử dụng các thông số được hỗ trợ
- Document doc = wordApp.Documents.Open(
- ref wFileName, ref wConfirmConversions, ref wReadOnly ,
- ref wAddToRecentFiles, ref wPasswordDocument, ref wPasswordTemplate,
- ref wRevert, ref wWritePasswordDocument, ref wWritePasswordTemplate,
- ref wFormat, ref wEncoding, ref wVisible, ref wOpenAndRepair,
- ref wDocumentDirection, ref wNoEncodingDialog, ref wXMLTransform);
- }
Note:
- wFileName: Đường dẫn tới file muốn mở. Lưu ý đây phải là đường dẫn tuyệt đối. Không hiểu sao thằng Word này nó không hiểu đường dẫn tương đối mặc dù file cần mở nằm chung file thực thi. Po' chi'u.
Để có thể lấy được đường dẫn tuyệt đối của file cần mở, các bạn lấy đường dẫn tuyệt đối của file thực thi rồi thêm vào tên file muốn mở như sau:
wFileName = System.IO.Directory.GetCurrentDirectory() + "\\demoMSWordAPI.suo"
- wConfirmConversions: được gán giá trị là true nếu muốn xuất hiện hộp thoại Convert File trong trường hợp tập tin được mở không đúng định dạng được hỗ trợ bởi MS Word
- wReadOnly: tập tin được mở chỉ để đọc không thể chỉnh sửa nếu được gán giá trị là true. Chúng ta sẽ thấy điều này khi lưu file
- wAddToRecentFiles: được gán giá trị là true nếu bạn muốn tên tập tin xuất hiện trong danh sách các tập tin được mở gần nhất ở menu File/Recent documents
- wPasswordDocument: mật khẩu được dùng để mở những tài liệu có password.
Nếu trường này là chuỗi rỗng hoặc không được sử dụng làm tham số trong hàm Open, thì khi tài liệu được mở ra sẽ xuất hiện hộp thoại yêu cầu nhập password. Còn nếu được sử dụng làm tham số thì MS Word sẽ sử dụng password này để mở tài liệu mà không cần yêu cầu nhập password.
- wPasswordTemplate: cũng tương tự wPasswordDocument nhưng được sử dụng cho tập tin dạng template.
- wRevert: Nếu trường này được gán giá trị là true thì MS Word sẽ bỏ qua tất cả những thay đổi đối với tập tin cùng tên đang được mở và mở lại tập tin đó. Nếu giá trị là false thì MS Word sẽ active cửa sổ đang mở tập tin đó
- wWritePasswordDocument: hiện tại mình chưa thấy được hiệu ứng của tham số này
- wWritePasswordTemplate: tương tự như wWritePasswordDocument nhưng hiện tại mình vẫn chưa thấy được hiệu ứng của tham số này
- wFormat: chọn định dạng sẽ mở tài liệu này. Có các định dạng sau:
wdOpenFormatAllWord A Microsoft Word format that is backward compatible with earlier versions of Microsoft Word.
wdOpenFormatAuto The existing format.
wdOpenFormatDocument Microsoft Word format.
wdOpenFormatEncodedText
Encoded text format.
wdOpenFormatRTF Rich text format (RTF).
wdOpenFormatTemplate As a Microsoft Word template.
wdOpenFormatText Unencoded text format.
wdOpenFormatUnicodeText Unicode text format.
wdOpenFormatWebPages HTML format.
wdOpenFormatXML XML format.
- wEncoding: loại bảng mã được sử dụng để mở tài liệu. Danh sách các bảng mã được hỗ trợ nằm trong enum Microsoft.Office.Core.MsoEncoding
- wVisible: Hiển thị tài liệu sau khi mở. Nếu bạn gán giá trị là false thì mặc dù tài liệu đã được mở nhưng sẽ không được thể hiện trong cửa sổ của MS Word.
- wOpenAndRepair: Nếu tài liệu có lỗi tập tin gì thì MS Word sẽ tự động sửa. Khi gán giá trị là true hay nói cách khác là sử dụng biến này thì MS Word sẽ tạo một tập tin mới với nội dung trong tập tin bạn truyền vào.
- wDocumentDirection: hướng thể hiện tài liệu. Có 2 giá trị là:
wdLeftToRight Left to right.
wdRightToLeft Right to left.
Bạn sẽ thấy hiệu ứng này khi mở một tài liệu khác Word
- wNoEncodingDialog: Nếu được thiết lập giá trị là true thì MS Word sẽ hiển thị hộp thoại yêu cầu chọn mã encoding khi MS Word không thể nhận ra được bảng mã đang sử dụng.
- wXMLTransform: mình chưa test được dạng này
Không có nhận xét nào:
Đăng nhận xét