最近有这样的一个需求:用C#把一些数据写到word中,生成一个报告,报告中多数内容是已知的只是某些地方需要从数据库中获取.查一些资料说可以使用模板,使用域什么的,请各位帮忙!

解决方案 »

  1.   

    http://wenku.baidu.com/view/0a8a6f11f18583d0496459b8.html
      

  2.   

    WORD模板中使用书签
    object nothing = System.Reflection.Missing.Value;
    object optional = System.Reflection.Missing.Value;
    Microsoft.Office.Interop.Word.ApplicationClass app = new Microsoft.Office.Interop.Word.ApplicationClass();Microsoft.Office.Interop.Word._Document Doc = app.Documents.Open(ref sFile, ref optional, ref docreadonly, ref optional, ref optional, ref optional, ref optional, ref optional, ref optional, ref optional, ref optional, ref visible, ref optional, ref optional, ref optional, ref optional);
    if (Doc.Books.Exists("Name"))
                    {
                        object b1 = "Name";
                        Word.Book bk1 = Doc.Books.get_Item(ref b1);
                        bk1.Range.Text = p.Title;";
                    }
      

  3.   

    我有完整的Demo,明天上班拷回来给你。
      

  4.   

    这个我看过,问题在于能不能使用word模板,生成报告时只需要用数据填充某些固定的域,这样会更方便.比如有个简历的模板,里面包含许多域如,姓名,性别,年龄等等,这些信息因人而异如果这些信息都存在数据库中,操作的时候可以选择这个模板,选择不同的人,就能生成对应的简历了...
      

  5.   

    c#生成的word文档的方法
    生成word文档 public class BiultReportForm 
       { 
       /// 
       /// word 应用对象 
       /// 
       private Microsoft.Office.Interop.Word.Application _wordApplication; 
       
       /// 
       /// word 文件对象 
       /// 
       private Microsoft.Office.Interop.Word.Document _wordDocument; 
       /// 
       /// 创建文档 
       /// 
       public void CreateAWord() 
       { 
       //实例化word应用对象 
       this._wordApplication = new Microsoft.Office.Interop.Word.ApplicationClass(); 
       Object myNothing = System.Reflection.Missing.Value; 
       
       this._wordDocument = this._wordApplication.Documents.Add(ref myNothing, ref myNothing, ref myNothing, ref myNothing); 
       } 
       /// 
       /// 添加页眉 
       /// 
       /// 
       public void SetPageHeader(string pPageHeader) 
       { 
       //添加页眉 
       this._wordApplication.ActiveWindow.View.Type =Microsoft .Office .Interop .Word.WdViewType.wdOutlineView; 
       this._wordApplication.ActiveWindow.View.SeekView = Microsoft.Office.Interop.Word.WdSeekView.wdSeekPrimaryHeader; 
       this._wordApplication.ActiveWindow.ActivePane.Selection.InsertAfter(pPageHeader); 
       //设置中间对齐 
       this._wordApplication.Selection.ParagraphFormat.Alignment =Microsoft .Office .Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter; 
       //跳出页眉设置 
       this._wordApplication.ActiveWindow.View.SeekView = Microsoft.Office.Interop.Word.WdSeekView.wdSeekMainDocument; 
       } 
       /// 
       /// 插入文字 
       /// 
       /// 文本信息 
       /// 字体打小 
       /// 字体颜色 
       /// 字体粗体 
       /// 方向 
       public void InsertText(string pText, int pFontSize, Microsoft.Office.Interop.Word.WdColor pFontColor, int pFontBold, Microsoft.Office.Interop.Word.WdParagraphAlignment ptextAlignment) 
       { 
       //设置字体样式以及方向 
       this._wordApplication.Application.Selection.Font.Size = pFontSize; 
       this._wordApplication.Application.Selection.Font.Bold = pFontBold; 
       this._wordApplication.Application.Selection.Font.Color= pFontColor; 
       this._wordApplication.Application.Selection.ParagraphFormat.Alignment = ptextAlignment; 
       this._wordApplication.Application.Selection.TypeText(pText); 
       } 
       
       
       /// 
       /// 换行 
       /// 
       public void NewLine() 
       { 
       //换行汽车配件网www.qichepeijian.com 
       this._wordApplication.Application.Selection.TypeParagraph(); 
       } 
       /// 
       /// 插入一个图片 
       /// 
       /// 
       public void InsertPicture(string pPictureFileName) 
       { 
       object myNothing = System.Reflection.Missing.Value; 
       //图片居中显示 
       this._wordApplication.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter; 
       this._wordApplication.Application.Selection.InlineShapes.AddPicture(pPictureFileName, ref myNothing, ref myNothing, ref myNothing); 
       } 
       /// 
       /// 保存文件 
       /// 
       /// 保存的文件名 
       public void SaveWord(string pFileName) 
       { 
       object myNothing = System.Reflection.Missing.Value; 
       object myFileName = pFileName; 
       object myWordFormatDocument =Microsoft .Office .Interop .Word.WdSaveFormat.wdFormatDocument; 
       object myLockd = false; 
       object myPassword = ""; 
       object myAddto = true; 
       try 
       { 
       this._wordDocument.SaveAs(ref myFileName, ref myWordFormatDocument, ref myLockd, ref myPassword, ref myAddto, ref myPassword, 
       ref myLockd, ref myLockd, ref myLockd, ref myLockd, ref myNothing, ref myNothing, ref myNothing, 
       ref myNothing, ref myNothing, ref myNothing); 
       } 
       catch 
       { 
       throw new Exception("导出word文档失败!"); 
       } 
       } 
       } 
      
      

  6.   


      public bool CreateWordFile(string _filename, "数据List或者你C#要写的数据")
            {
                           #region 开始生成Word
                try
                {                string strtitle = "任务导出";
                    object oEndOfDoc = "\\endofdoc";
                    Object Nothing = System.Reflection.Missing.Value;
                    Object filename = _filename;
                    //创建Word文档                Microsoft.Office.Interop.Word.Application WordApp = new Microsoft.Office.Interop.Word.ApplicationClass();
                    Microsoft.Office.Interop.Word.Document WordDoc = WordApp.Documents.Add(ref Nothing, ref Nothing, ref Nothing, ref Nothing);
                    //设置页眉
                    WordApp.ActiveWindow.View.Type = Microsoft.Office.Interop.Word.WdViewType.wdOutlineView;
                    WordApp.ActiveWindow.View.SeekView = Microsoft.Office.Interop.Word.WdSeekView.wdSeekPrimaryHeader;
                    WordApp.ActiveWindow.ActivePane.Selection.InsertAfter("WPFOA任务导出");
                    WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphRight;//设置右对齐
                    WordApp.ActiveWindow.View.SeekView = Microsoft.Office.Interop.Word.WdSeekView.wdSeekMainDocument;//跳出页眉设置
                    //任务导出------名字
                    Word.Paragraph oPara1;
                    oPara1 = WordDoc.Content.Paragraphs.Add(ref Nothing);
                    oPara1.Range.Text = strtitle;
                    oPara1.Range.Font.Bold = 1;
                    oPara1.Range.Font.Name = "宋体";
                    oPara1.Range.Font.Size = 20;
                    oPara1.Range.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphCenter;
                    oPara1.Format.SpaceAfter = 5;    //24 pt spacing after paragraph.
                    oPara1.Range.InsertParagraphAfter();
                    #region 循环每个表                foreach (var v in lst_task)
                    {
                        #region 循环每一个列,产生一行数据
                        //描述信息
                        Word.Paragraph oPara3;
                        object oRng = WordDoc.Books.get_Item(ref oEndOfDoc).Range;
                        oPara3 = WordDoc.Content.Paragraphs.Add(ref oRng);
                        oPara3.Range.Text = "";
                        oPara3.Range.Font.Bold = 0;
                        oPara3.Range.Font.Name = "宋体";
                        oPara3.Range.Font.Size = 9;
                        oPara3.Range.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphCenter;
                        oPara3.Format.SpaceBefore = 1;
                        oPara3.Format.SpaceAfter = 1;
                        oPara3.Range.InsertParagraphAfter();                    //插入表格          
                        Word.Table newTable;
                        Word.Range wrdRng = WordDoc.Books.get_Item(ref oEndOfDoc).Range;
                        newTable = WordDoc.Tables.Add(wrdRng, 5, 4, ref Nothing, ref Nothing);
                        newTable.Columns[1].Width = 60;
                        newTable.Columns[2].Width = 145;
                        newTable.Columns[3].Width = 80;
                        newTable.Columns[4].Width = 145;
                        newTable.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;
                        newTable.Borders.InsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;                    //填充表格内容
                        newTable.Cell(1, 1).Range.Text = "项目名称";
                       newTable.Cell(1, 2).Range.Text = "1";
                        newTable.Cell(1, 3).Range.Text = "模块名称";
                        newTable.Cell(1, 4).Range.Text = "2";
                        newTable.Cell(2, 1).Range.Text = "负责人名";
                        newTable.Cell(2, 2).Range.Text = "3";
                        newTable.Cell(2, 3).Range.Text = "状态";
                        newTable.Cell(2, 4).Range.Text = "4";
                        newTable.Cell(3, 1).Range.Text = "发布时间";
                        newTable.Cell(3, 2).Range.Text = "5";
                        newTable.Cell(3, 3).Range.Text = "要求完成时间";
                        newTable.Cell(3, 4).Range.Text = "6";
                        newTable.Cell(4, 1).Range.Text = "完成时间";
                        newTable.Cell(4, 2).Range.Text = "7";
                        newTable.Cell(4, 3).Range.Text = "分配人";
                        newTable.Cell(4, 4).Range.Text = "8";
                        newTable.Cell(5, 1).Range.Text = "任务描述";
                        newTable.Cell(5, 2).Merge(newTable.Cell(5, 4));
                        newTable.Cell(5, 2).Range.ParagraphFormat.Alignment = Word.WdParagraphAlignment.wdAlignParagraphLeft;
                        newTable.Cell(5, 2).Range.Text = "12313213123213";
                        #endregion
                    }
                    WordDoc.SaveAs(ref filename, ref Nothing, ref Nothing, ref Nothing,
                     ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing,
                     ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing,
                     ref Nothing, ref Nothing);                WordDoc.Close(ref Nothing, ref Nothing, ref Nothing);
                    WordApp.Quit(ref Nothing, ref Nothing, ref Nothing);
                    #endregion
                    //关闭WinWord进程
                    System.Diagnostics.Process[] MyProcess = System.Diagnostics.Process.GetProcessesByName("WINWORD");
                    MyProcess[0].Kill();
                    return true;            }
                catch
                {                System.Diagnostics.Process[] MyProcess = System.Diagnostics.Process.GetProcessesByName("WINWORD");
                    MyProcess[0].Kill();
                    return false;
                }
                #endregion
            }
      

  7.   

    我已经把导出的方法给你粘贴出来了,
    想要Demo的话明天给你,这个方法在我在项目中弄出来的,跟我这个方法逻辑思路是一样的
      

  8.   

    newTable = WordDoc.Tables.Add(wrdRng, 5, 4, ref Nothing, ref Nothing);
    这个代表(5,4)5行4列
      

  9.   

    这个好像可以,就是那个Open方法里面这么多参数都是做什么用的,MSDN上没找到答案,请指教!
      

  10.   

    请问一下为什么我的程序中这样写老报错呢
    Microsoft.Office.Interop.Word.ApplicationClass WordApp = new Microsoft.Office.Interop.Word.ApplicationClass();ApplicationClass不让用,说让我选用适当的接口,只能用Application,这是怎么回事
    还有就是我保存word文档时也出现异常,保存失败为什么啊,我是这样写的
    WordDoc.SaveAs(ref filename, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing,
                        ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing);
                    WordDoc.Close(ref Nothing, ref Nothing, ref Nothing);
                    WordApp.Quit(ref Nothing, ref Nothing, ref Nothing);