C#实现读取二维数组集合并输出到Word预设表格

 更新时间:2024年03月22日 08:48:39   作者:初九之潜龙勿用  
这篇文章主要为大家详细介绍了如何使用C#实现读取二维数组集合并输出到Word预设表格,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

应用场景

存储或导出个人WORD版简历是招聘应用系统中的常用功能,我们通常会通过应用系统采集用户的个人简历信息到数据库,许多情况下我们会读取数据记录导出到WORD文件中,以便汇总、打印。其中,WORD表格元素是经常会被用到的,比如问卷调查表格、教育经历表格、工作经历表格等等。

设计约定

1、设计WORD模板,在需要输出值的地方绘制表格,表格的数量对应输出的数据表数量。

2、根据条件查询数据表,生成 DataSet ,遍历 Tables ,生成对应的二维数组集合,将数据输出到对应的WORD表格中。

3、按约定,WORD表格的数量应该大于等于 DataSet 里的 Tables 数量。

4、按参数设定对应的WORD表格ID序号,如参数设定为2,则表示输出到WORD文件中的第二个表格中。(注意:WORD表格序号以1为开始)

在输出写入的方式中,我们约定有两种方式:

一为覆盖式写入(即已预知数据输出模式)举例如下图:

二为动态式写入(即未知数据行数量)举例如下图:

范例运行环境

操作系统: Windows Server 2019 DataCenter

操作系统上安装 Office Word 2016

数据库:Microsoft SQL Server 2016

.net版本: .netFramework4.7.1 或以上

开发工具:VS2019  C#

配置Office DCOM

配置方法可参照我的文章《C# 读取Word表格到DataSet》进行处理和配置。

实现代码

组件库引入

核心代码

DataSet转二维数组

public object[,] DataSetToObjectData(DataSet ds,int TableId,bool hastitle),该方法提供3个参数,DataSet数据集、指定表索引、导出是否包含标题列名称。

        public object[,] DataSetToObjectData(DataSet ds,int TableId,bool hastitle)
        {
            ArrayList rowdata = new ArrayList();
            int _fieldcount=ds.Tables[TableId].Columns.Count;
            Object[] colvalues = new Object[_fieldcount];
            for(int i=0;i<_fieldcount;i++)
            {
                colvalues[i]=ds.Tables[TableId].Columns[i].ColumnName;
            }
            if(hastitle)
                rowdata.Add(colvalues);
            for(int i=0;i<ds.Tables[TableId].Rows.Count;i++)
            {
                Object[] values = new Object[_fieldcount];
                values=ds.Tables[TableId].Rows[i].ItemArray;
                rowdata.Add(values);
                RowsCount++;
            }
            object[,] rv=new object[rowdata.Count,_fieldcount];
            for(int i=0;i<rowdata.Count;i++)
            {
                for(int j=0;j<_fieldcount;j++)
                {
                    rv[i,j]=((object[])rowdata[i])[j];
                }
            }
            return rv;
        }

导出写入WORD表格

public string DataSetToWordTables(string _filename,int[,] _drawtype,object[] _datas),该方法提供3个参数,使用的WORD模板文件路径、写入配置(包括要写入的WORD表格ID,写入方式:0为覆盖;1为从第二行动态追加;3为从第一行动态追加)、对应的二维数组集合。

public string DataSetToWordTables(string _filename,int[,] _drawtype,object[] _datas)        {
            Object Nothing = System.Reflection.Missing.Value;
            object filename = _filename;
            //创建一个名为WordApp的组件对象
            Word.Application WordApp = new Word.Application();
            //创建一个名为WordDoc的文档对象
            WordApp.DisplayAlerts = Word.WdAlertLevel.wdAlertsNone;
 
            Word.Document WordDoc = WordApp.Documents.Open(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.SpellingChecked = false;//关闭拼写检查
 
            WordDoc.ShowSpellingErrors = false;//关闭显示拼写错误提示框
 
                for(int i=_drawtype.GetLength(0)-1;i>=0;i--)
                {
                    int _tableid=_drawtype[i,0];
                    int _draw=_drawtype[i,1];
                    object[,] r_datas=(object[,])_datas[i];
                    int _rowscount=r_datas.GetLength(0);
                    if (_rowscount == 0)
                    {
                        WordDoc.Tables[_tableid].Delete();
                        continue;
                    }
                    int startrowid = 2;
                    if (_draw == 3)
                    {
                        startrowid = 1;
                    }
                    if(_draw==1||_draw==3)
                    {
                        object _row=(object)WordDoc.Tables[_tableid].Rows[startrowid];
                        for(int j=0;j<_rowscount-1;j++)
                        {
                            WordDoc.Tables[_tableid].Rows.Add(ref _row);
 
                        }
                    }
                    for (int k = 0; k < r_datas.GetLength(0); k++)
                    {
                        for(int m=0;m<r_datas.GetLength(1);m++)
                        {
                            WordDoc.Tables[_tableid].Cell(k + startrowid, m + 1).Range.Text = r_datas[k, m].ToString();
                        }
                    }
                }
 
            WordDoc.Save();
            WordDoc.Close(ref Nothing, ref Nothing, ref Nothing);
            //关闭WordApp组件对象
            WordApp.Quit(ref Nothing, ref Nothing, ref Nothing);
    return "";
}

调用举例

如下为示例代码:

string _filename=@"x:\test.docx";
int[,] _drawtype=new int[2,2];
_drawtype[0,0]=1;  //写入WORD第一个表格
_drawtype[0,1]=0;  //覆盖式写入
 
_drawtype[1,0]=2;  //写入WORD第二个表格
_drawtype[1,1]=1;  //动态追加行写入
 
object[] _datas=new object[2];
DataSet ds=getDataSet(); //获取DataSet对象
_datas[0]=DataSetToObjectData(ds,0,false); //获取DataSet Tables[0]的二维数组数据
_datas[1]=DataSetToObjectData(ds,1,false); //获取DataSet Tables[1]的二维数组数据
 
string result=DataSetToWordTables(_filename,_drawtype,_datas);  //写入Word表格        

小结

1、核心代码中对无数据的表格采取了删除WORD表格的操作。

2、预设表格的优点在于所见即所得,样式设计简单化,便于理解输出,我们还可以采用关键字定位并动态添加WORD表格的形式进行输出,来实现更加复杂的样式等。

3、核心代码中输出的起始行为第2行,根据设置也可以为第1行。如果我们设计的表格比较复杂(如包括合并单元格等),则可以对 _drawtype进行改造,增加一个参数,用于指定从第几行开始进行输出。

到此这篇关于C#实现读取二维数组集合并输出到Word预设表格的文章就介绍到这了,更多相关C#读取二维数组并输出到Word内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#实现汉字转区位码的示例代码

    C#实现汉字转区位码的示例代码

    区位码是一个4位的十进制数,每个区位码都对应着一个唯一的汉字,区位码的前两位叫做区码,后两位叫做位码,下面我们就来看看如何使用C#实现汉字转区位码吧
    2024-01-01
  • c#实现flv解析详解示例

    c#实现flv解析详解示例

    本文提供的解析程序简单的把FLV分解了出来,如果要做FLV的修改操作的话,可以给每个类加个toStream方法,再历遍依次调用就可以写回到文件里了
    2014-01-01
  • 基于C# 实现 OPC DA Server的问题小结

    基于C# 实现 OPC DA Server的问题小结

    这篇文章主要介绍了基于C# 实现 OPC DA Server的相关知识,关于C#怎么编写一个进程外的DCOM组件,这里先不做介绍了,这里主要介绍下OPC DA Server 的第一个接口,感兴趣的朋友跟随小编一起看看吧
    2024-04-04
  • WPF自定义控件实现ItemsControl鱼眼效果

    WPF自定义控件实现ItemsControl鱼眼效果

    这篇文章主要为大家详细介绍了WPF如何通过自定义控件实现ItemsControl鱼眼效果,文中的示例代码讲解详细,需要的可以参考一下
    2024-01-01
  • WPF使用HLSL实现百叶窗动画效果

    WPF使用HLSL实现百叶窗动画效果

    百叶窗动画是制作PPT时常用的动画之一,本文将通过实现百叶窗动画效果的例子介绍在WPF中如何使用ShaderEffect,感兴趣的小伙伴可以了解一下
    2023-09-09
  • C#多态的三种实现方式(小结)

    C#多态的三种实现方式(小结)

    这篇文章主要介绍了C#多态的三种实现方式(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • C#中线程安全问题的调试和解决

    C#中线程安全问题的调试和解决

    在C#中,多线程编程是一种常见且强大的工具,但它带来了线程安全的问题,本文将介绍如何调试和解决C#中的线程安全问题,并深入探讨锁机制、并发控制以及调试的最佳实践,需要的朋友可以参考下
    2025-03-03
  • C#实现无损压缩图片代码示例

    C#实现无损压缩图片代码示例

    这篇文章介绍了C#实现无损压缩图片的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • C#拷贝整个文件夹及子目录和其中文件的方法

    C#拷贝整个文件夹及子目录和其中文件的方法

    这篇文章主要介绍了C#拷贝整个文件夹以及子目录和其中文件,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-06-06
  • C#保存与读取DataTable信息到XML格式的方法

    C#保存与读取DataTable信息到XML格式的方法

    这篇文章主要介绍了C#保存与读取DataTable信息到XML格式的方法,实例分析了C#读取DataTable信息到XML格式及读取XML格式数据到DataTable的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08

最新评论