Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/csharp-4.0/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Automation 办公自动化_Automation_C# 4.0_Ms Office - Fatal编程技术网

Automation 办公自动化

Automation 办公自动化,automation,c#-4.0,ms-office,Automation,C# 4.0,Ms Office,我试图制作一个程序,将数据插入现有word文档中的特定位置,并保存其副本。 我不知道该怎么做,也找不到关于Office2010自动化的好资源。 有人能给我指出正确的方向和/或给我举一些例子吗 提前谢谢 “找到解决方案”将在稍后添加答案以下是我是如何做到的,这可能不是最好的方法,但它很有效 添加对office互操作的引用 using Microsoft.Office.Interop.Word; using Word = Microsoft.Office.Interop.Word; using Ex

我试图制作一个程序,将数据插入现有word文档中的特定位置,并保存其副本。 我不知道该怎么做,也找不到关于Office2010自动化的好资源。 有人能给我指出正确的方向和/或给我举一些例子吗

提前谢谢


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

以下是我是如何做到的,这可能不是最好的方法,但它很有效

添加对office互操作的引用

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:\test.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:\test.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:\t\test"+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);
我希望这对某人有所帮助: