在winform中,将数据库中的数据导出到word中,该怎么做??谢谢大家的帮忙

解决方案 »

  1.   

    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;";
      } 
     
    table
    Word.Range oRng = Doc.Books.get_Item(ref oEndOfDoc).Range;
      Word.Table tb = Doc.Tables.Add(oRng, 1, 7, ref nothing, ref nothing);
      tb.Rows.Alignment = Word.WdRowAlignment.wdAlignRowCenter;
      tb.Borders.OutsideLineStyle = Word.WdLineStyle.wdLineStyleSingle;
      

  2.   


     /// <summary>
      /// 打开Word文档,并且返回对象wDoc,wDoc
      /// </summary>
      /// <param name="FileName">完整Word文件路径 名称</param>  
      /// <param name="wDoc">返回的Word.Document wDoc对象</param>
      /// <param name="WApp">返回的Word.Application对象</param>
      public static void CreateWordDocument(string FileName,ref Word.Document wDoc,ref  Word.Application WApp)
      {
       if(FileName == "") return;
       Word.Document thisDocument = null;
       Word.FormFields   formFields = null;
       Word.Application thisApplication = new Word.ApplicationClass();
       thisApplication.Visible = true;
       thisApplication.Caption = "";
       thisApplication.Options.CheckSpellingAsYouType = false;
       thisApplication.Options.CheckGrammarAsYouType = false;
       Object filename = FileName;
       Object ConfirmConversions = false;
       Object ReadOnly = true;
       Object AddToRecentFiles = false;
       Object PasswordDocument = System.Type.Missing;
       Object PasswordTemplate = System.Type.Missing;
       Object Revert = System.Type.Missing;
       Object WritePasswordDocument = System.Type.Missing;
       Object WritePasswordTemplate = System.Type.Missing;
       Object Format = System.Type.Missing ;
       Object Encoding = System.Type.Missing;
       Object Visible = System.Type.Missing;
       Object OpenAndRepair = System.Type.Missing;
       Object DocumentDirection =  System.Type.Missing;
       Object NoEncodingDialog = System.Type.Missing;
       Object XMLTransform = System.Type.Missing;
       try
       {
        Word.Document wordDoc =
         thisApplication.Documents.Open(ref filename, ref ConfirmConversions,
         ref ReadOnly, ref AddToRecentFiles, ref PasswordDocument, ref PasswordTemplate,
         ref Revert,ref WritePasswordDocument, ref WritePasswordTemplate, ref Format,
         ref Encoding, ref Visible, ref OpenAndRepair, ref DocumentDirection,
         ref NoEncodingDialog, ref XMLTransform );
       
        thisDocument = wordDoc;
        wDoc = wordDoc;
        WApp = thisApplication;
        formFields = wordDoc.FormFields;
       }
       catch(Exception ex)
       {
        MessageBox.Show(ex.Message);
       }
      
      }
      #endregion
    调用上面静态方法,打开目标文件并且把DataGrid中数据填充到对应Word标签中去
    #region Word填充数据(For Example)
      /// <summary>
      /// Word填充数据
      /// </summary>
      private void WordLoadData()
      {
       Word.Document wDoc=null;
       Word.Application wApp=null;
       sysFun.CreateWordDocument("E:\\监测报告(new).dot",ref wDoc,ref wApp);
       //对标签"C"进行填充
       object bkmC="C";
       if(wApp.ActiveDocument.Books.Exists ("C") == true)
       {
        wApp.ActiveDocument.Books.get_Item
         (ref bkmC).Select();
       }
       wApp.Selection.TypeText(this.txt1.Text);
       object bkmG = "TWaterTable3";
       object unit;
       object count; //移动数
       object extend;
       
       extend = Word.WdMovementType.wdExtend;
       unit = Word.WdUnits.wdCell;
       //把DataGrid中数据填充到标签TWaterTable3上
       if(wApp.ActiveDocument.Books.Exists("TWaterTable3") == true)
       {
        wApp.ActiveDocument.Books.get_Item
         (ref bkmG).Select();
        for(int i=0;i<this.gridEX1.RecordCount;i )
        {
         if(i==0)
         {
          count=1;
         }
         else
         {
          count=0;
         }
         //需填充5列数据
         wApp.Selection.Move(ref unit,ref count);
         wApp.Selection.TypeText(gridEX1.GetRow(i).Cells[0].Text);
         count=1;
         
         wApp.Selection.Move(ref unit,ref count);
         wApp.Selection.TypeText(gridEX1.GetRow(i).Cells[1].Text);
         
         wApp.Selection.Move(ref unit,ref count);
         wApp.Selection.TypeText(gridEX1.GetRow(i).Cells[2].Text);
         
         wApp.Selection.Move (ref unit,ref count);
         wApp.Selection.TypeText(gridEX1.GetRow(i).Cells[3].Text);
        
         wApp.Selection.Move(ref unit,ref count);
         wApp.Selection.TypeText(gridEX1.GetRow(i).Cells[4].Text);
         //换行
         wApp.Selection.MoveRight(ref unit,ref count,ref extend);
        }
       }
      }