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