C# office 2010 自动化 [英] C# office 2010 automation

查看:44
本文介绍了C# office 2010 自动化的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试制作一个程序,将数据插入到现有 Word 文档中的特定位置并保存它的副本.我不知道怎么做,我找不到任何关于 Office 2010 自动化的好资源.谁能指出我正确的方向和/或给我一些例子.

i'm trying to make a program that inserts data into specific places in existing word document and saves a copy of it. and i have no clue how to do it , and i cant find any good resource on office 2010 automating. can anyone point me in the right direction and/or give me some examples.

提前致谢.

找到解决方案将在稍后添加答案

found a solution will add an answer later on

推荐答案

我是这样做的,它可能不是最好的方法,但它确实有效!

Here is how i did it , it may not be the best way , but its working !

添加对办公室互操作的引用

add references to the office interop

using Microsoft.Office.Interop.Word;
using Word = Microsoft.Office.Interop.Word;
using Excel = Microsoft.Office.Interop.Excel;


          //defines new excel and workd apps
            var ap = new Word.Application();
            var excelApp = new Excel.Application();
            // defines new excel worksheet & workbooks
            Excel.Workbook exBook;
            Excel.Worksheet xlWorkSheet;
            // should the excell/word apps be visible ? 
            excelApp.Visible = false;
            ap.Visible = false;

            //defining the index numbers of our content controls that are in the word template
            // index numbers start from 1 and are numbered by order of creation
            object Price, Name, address;
            Price = 1;
            Name = 2;
            address = 3;


            // here we open the excell file
            exBook = excelApp.Workbooks.Open(@"C:	est.xls");
            // and we open the first worksheet
            xlWorkSheet = exBook.Worksheets.get_Item(1);
            Excel.Range range ;
            //here we select the first worksheet and make it active
            Excel._Worksheet workSheet = (Excel.Worksheet) excelApp.ActiveSheet;
            //we open the word document
            var doc = ap.Documents.Open(@"C:	est.dotx", ReadOnly: false, Visible: false);
            // and we assign the content controls 
            var dPrice = doc.ContentControls.get_Item(ref Price);
            var dName = doc.ContentControls.get_Item(ref Name);
            var dAddress = doc.ContentControls.get_Item(ref address);
            doc.Activate();
            range = xlWorkSheet.UsedRange;
            // here we define the columns that we are going to select
            object t, P , E , K, N,M,J;

            P = "P";
            E = "E";
            K = "K";
            J  = "J";
            N = "N";
            M = "M";

            // and here we loop trought the rows of the excell worksheet
            // IMPORTANT! excell rows count starts from 1 and not from 0 !
         for (int i =1; i< Convert.ToInt16(Settings1.Default.copies) ;i++)

            {

                t = i;
                // here we get the value if cell t(1..2..3..etc), P
                var dummy = (range.Cells[t, P] as Excel.Range).Value2;
                // here we insert the content of the cell to the content control

                dPrice.Range.Text = ": " + Convert.ToString(dummy) + " лв";
                dName.Range.Text = ": " + (string)(range.Cells[t, E] as Excel.Range).Value2;

                // same thing here
                var city = (string) (range.Cells[t, J] as Excel.Range).Value2;
                var address1 = (string) (range.Cells[t, K] as Excel.Range).Value2;
                var city2 = (string) (range.Cells[t, M] as Excel.Range).Value2;
                var address2 = (string) (range.Cells[t,N] as Excel.Range).Value2;
                if (!string.IsNullOrEmpty(city2) && city2 != " " && !string.IsNullOrEmpty(address2) && address2 != " ")
                {
                    dAddress.Range.Text = ": " +city.Normalize() + " " + address1.Normalize() + " , " + city2.Normalize() + " " + address2.Normalize() ;

                }
                else
                {
                    dAddress.Range.Text = ": " + city.Normalize() + " " + address1.Normalize();
                }


                try
                {
                    //here we try to save the word document as a pdf file
                    object name = @"C:		est"+i+".pdf";
                    object FileFormat = WdSaveFormat.wdFormatPDF;
                    doc.SaveAs(ref name, ref FileFormat);

                }
                catch (Exception ex)
                {
                    MessageBox.Show("Exception Caught: " + ex.Message +" source "+ ex.Source.ToString());

                }

            }
            // here quit word without saving the changes to the template  
            ap.Quit(SaveChanges: false, OriginalFormat: false, RouteDocument: false);
            excelApp.Quit();
            // and we release the objects 
            System.Runtime.InteropServices.Marshal.ReleaseComObject(ap);
            System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);

我希望这对某人有帮助:)

i hope this was helpful to someone :)

这篇关于C# office 2010 自动化的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆