• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C#——操作Word并导出PDF

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

一、操作Word 

  首先引用这个DLL,Microsoft.Office.Interop.Word,官方提供的。

  可以操作word文字,表格,图片等。

  文字通过替换关键字的方式实现

  document.Paragraphs[i].Range.Text = temptext.Replace("{$village}", "HELLO WORLD");

  表格可以自己获取模板中已有的表格

   Microsoft.Office.Interop.Word.Table table1 = document.Tables[1];

   table1.Cell(1, 1).Range.Text = "TEST1";

  也可以自己创建表格,可以设计表头,单元格等。

 

   int tableRow = 6 ;
   int tableColumn = 6;
    //定义一个Word中的表格对象
   Microsoft.Office.Interop.Word.Table table = document.Tables.Add(document.Paragraphs[i].Range,
   tableRow, tableColumn, ref Nothing, ref Nothing);
   //默认创建的表格没有边框,这里修改其属性,使得创建的表格带有边框 
   table.Borders.Enable = 1;
   table.Cell(1, 1).Merge(table.Cell(2, 1));//纵向合并
   table.Cell(1, 1).Range.Text = "牌号/代码";

   table.Cell(1, 2).Merge(table.Cell(2, 2));//纵向合并
   table.Cell(1, 2).Range.Text = "标准编号";
  有一篇文章写的很详细可以参考下:https://www.cnblogs.com/xh6300/p/5915717.html

 

public bool CreateWord(DataTable dttmp)
        {
            bool result = false;
            Object Nothing = Missing.Value;
            Microsoft.Office.Interop.Word.Application application = new Microsoft.Office.Interop.Word.Application();
            Microsoft.Office.Interop.Word.Document document = null;
            string path = @"C:\Users\Administrator\Desktop\BB\合同模版.doc";
            object FileName = @"C:\Users\Administrator\Desktop\BB\" + DateTime.Now.ToString("yyyyMMddHHmmssffffff") + ".doc";
            application.Visible = false;
            document = application.Documents.Open(path);

            int rowNum = dttmp.Rows.Count;
            for (int i = 1; i <= document.Paragraphs.Count; i++)
            {
                string temptext = document.Paragraphs[i].Range.Text;
                //以下为替换文档模版中的关键字
                if (temptext.Contains("{$village}"))
                    document.Paragraphs[i].Range.Text = temptext.Replace("{$village}", "HELLO WORLD");
                Microsoft.Office.Interop.Word.Table table1 = document.Tables[1];
                table1.Cell(1, 1).Range.Text = "TEST1";
                if (temptext.Contains("{$Table1}"))
                {
                    //设置表格的行数和列数
                    int tableRow = 6 + rowNum;
                    int tableColumn = 13;
                    //定义一个Word中的表格对象
                   

                    Microsoft.Office.Interop.Word.Table table = document.Tables.Add(document.Paragraphs[i].Range,
                      tableRow, tableColumn, ref Nothing, ref Nothing);
                    //默认创建的表格没有边框,这里修改其属性,使得创建的表格带有边框 
                     table.Borders.Enable = 1;//这个值可以设置得很大
                     table.Cell(1, 1).Merge(table.Cell(2, 1));//纵向合并
                     table.Cell(1, 1).Range.Text = "牌号/代码";

                     table.Cell(1, 2).Merge(table.Cell(2, 2));//纵向合并
                     table.Cell(1, 2).Range.Text = "标准编号";

                 

                     table.Cell(1, 6).Merge(table.Cell(2, 6));
                     table.Cell(1, 6).Range.Text = "单重\n(MT)";

                     table.Cell(1, 7).Merge(table.Cell(2, 7));
                     table.Cell(1, 7).Range.Text = "张数";
                     
                     table.Cell(1, 8).Merge(table.Cell(2, 8));
                     table.Cell(1, 8).Range.Text = "重量\n(MT))";
                  
                     

                     table.Cell(1, 9).Merge(table.Cell(2, 9));
                     table.Cell(1, 9).Range.Text = "单价\n(元/吨)";
                                        
                     table.Cell(1, 10).Merge(table.Cell(2, 10));
                     table.Cell(1, 10).Range.Text = "金额(人民币)";
                                      
         
                     table.Cell(1, 13).Merge(table.Cell(2, 13));
                     table.Cell(1, 13).Range.Text = "交货期";

                     table.Cell(1, 3).Merge(table.Cell(1, 5));//横向合并
                     table.Cell(1, 3).Range.Text = "规格(mm)";
                     table.Cell(2, 3).Range.Text = "厚度";
                     table.Cell(2, 4).Range.Text = "宽度";
                     table.Cell(2, 5).Range.Text = "宽度";

                     table.Cell(1, 9).Merge(table.Cell(1, 10));
                     table.Cell(1, 10).Range.Text = "表面加工";
                     table.Cell(2, 11).Range.Text = "边缘";
                     table.Cell(2, 11).Range.Text = "精度";
                
                }
            }
           
            object format = document.SaveFormat;
            document.Save();

            application.Quit(ref Nothing, ref Nothing, ref Nothing);
            return result;

        }

二、Word导出PDF

  

 public bool WordToPDF(string sourcePath)
        {
            bool result = false;
           Microsoft.Office.Interop.Word.Application application = new Microsoft.Office.Interop.Word.Application();
            Microsoft.Office.Interop.Word.Document document = null;
            try
            {
                application.Visible = false;
                document = application.Documents.Open(sourcePath);
                string PDFPath = sourcePath.Replace(".doc", ".pdf");//pdf存放位置
                if (!File.Exists(@PDFPath))//存在PDF,不需要继续转换
                {
                    document.ExportAsFixedFormat(PDFPath, Microsoft.Office.Interop.Word.WdExportFormat.wdExportFormatPDF);
                }
                result = true;
            }
            catch (Exception e)
            {
                Console.WriteLine(e.Message);
                result = false;
            }
            finally
            {
                //document.Close();
            }
            return result;
        }

 服务器部署可以参考;https://www.cnblogs.com/5426z/articles/4865312.html


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap