C#使用动态链接库打印Word表格适用于各类系统中的Word导出

C#使用动态链接库打印Word表格适用于各类系统中的Word导出

在很多项目中都会使用到Word导出功能,这里介绍C#用Word动态链接库导出生成Word文档的方法,添加引用方法如下:选中当前项目,单击右键,选择“添加引用”选项,在弹出的“添加引用”对话框中选择“COM”选项卡,然后找到要引用的Word动态链接库,单击“确定”按钮即可。
废话不多说直接上代码

        public bool ExportDataGridview(DataGridView dgv, bool isShowWord)

        {

            Word.Document mydoc = new Word.Document();     //实例化一个Word对象

            Word.Table mytable;                                 //定义一个Table型的对象

            Word.Selection mysel;                                      //定义一个mysel

            Object myobj;                                          //定义一个Object型的myobj

            if (dgv.Rows.Count == 0)                                //当DataGridView控件中不存在内容时

                return false;                                      //返回false

            Word.Application word = new Word.Application();     //建立Word对象

            myobj = System.Reflection.Missing.Value;          //实例化对象myobj

            mydoc = word.Documents.Add(ref myobj, ref myobj, ref myobj, ref myobj); //实例化对象mydoc

            word.Visible = isShowWord;                                    //设置word的显示格式

            mydoc.Select();                                        //调用对象的Select方法

            mysel = word.Selection;                                          //实例化mysel

            //将数据生成Word表格文件

            mytable = mydoc.Tables.Add(mysel.Range, dgv.RowCount, dgv.ColumnCount, ref myobj, ref myobj);

            mytable.Columns.SetWidth(30, Word.WdRulerStyle.wdAdjustNone);        //设置列宽

            for (int i = 0; i < dgv.ColumnCount; i++)            //输出列标题数据

            {

                mytable.Cell(1, i + 1).Range.InsertAfter(dgv.Columns[i].HeaderText);      //向表格中插入数据

            }

            for (int i = 0; i < dgv.RowCount - 1; i++)            //输出控件中的记录

            {

                for (int j = 0; j < dgv.ColumnCount; j++)            //循环遍历DataGridView控件中的每一列

                {

                    mytable.Cell(i + 2, j + 1).Range.InsertAfter(dgv[j, i].Value.ToString());     //向表格中插入数据

                }

            }

            return true;                                                                          //返回true

        }

分享是一种美德,有时候牛逼的文章可以提高我们的技术层面,但有时候更多的需求是业务层面,很多小知识应用的分享却可以帮我们提高业务层面的问题。只要分享的知识点有用,不误人子弟,哪怕大小都是一种学习,所以也希望大家能勇于分享。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值