如何使用免费控件将Word表格中的数据导入到Excel中

如何使用免费控件将Word表格中的数据导入到Excel中

我通常使用MS Excel来存储和处理大量数据,但有时候经常会碰到一个问题—我需要的数据存储在word表格中,而不是在Excel中,这样处理起来非常麻烦,尤其是在数据比较庞大的时候,

这时我迫切地需要将word表格中的数据导入到Excel中。相信大家也碰到过同样的问题,下面我就给大家分享一下在C#中如何使用免费控件来实现这一功能。这里,我使用了两个免费API,

DocX和Spire.Xls。

有需要的朋友可以下载使用。下载地址:

DocX:codeplex官网

Spire.Xls: E-iceblue官网

注意:在创建项目后,需要添加这两个控件的相关.dll文件作为项目的引用。

 

如何使用免费控件将Word表格中的数据导入到Excel中                       

 

以下是详细步骤:

首先我使用DocX API 来获取word表格中的数据,然后将数据导入System.Data.DataTable对象中

代码片段:

步骤1:加载word文档;

DocX document = DocX.Load("E:\\Program Files\\data.docx");

步骤2从文档中获取表格。作为示例,这里我仅获取了第一个表格;

//获取文档的第一个表格

Table table = document.Tables[0];

步骤3创建一个DataTable对象,并导入word表格中的数据;

//创建一个Datable对象并命名为order

DataTable dt = new DataTable("order");

//将word表格中的数据导入Datable

DataColumn column;

for (int i = 0; i < table.ColumnCount; i++)

{

column = new DataColumn();

column.ColumnName = table.Rows[0].Cells[i].Paragraphs[0].Text;

dt.Columns.Add(column);

}

DataRow newRow;

for (int i = 1; i < table.RowCount; i++)

{

newRow = dt.NewRow();

Row row = table.Rows[i];

for (int j = 0; j < table.ColumnCount; j++)

{

newRow[j] = row.Cells[j].Paragraphs[0].Text;

}

dt.Rows.Add(newRow);

}

效果图如下:

原word文档:

如何使用免费控件将Word表格中的数据导入到Excel中 

Datable:

如何使用免费控件将Word表格中的数据导入到Excel中 

 

其次,我使用了Spire.Xls API来创建一个Workbook对象,并将dataTable插入到Workbook中,然后将文件保存为.xlsx文件。

代码片段:

步骤1创建一个Workbook实例并新建一个空的worksheet;

//创建一个Workbook示例

Workbook workbook = new Workbook();

//新建一个空的worksheet

workbook.CreateEmptySheets(1);

//获取第一个worksheet

Worksheet sheet = workbook.Worksheets[0];

步骤2将dataTable中的数据导入到worksheet;

//将dataTable中的数据插入到worksheet中,1代表第一行和第一列

sheet.InsertDataTable(dt, true, 1, 1);

步骤3 保存到一个excel文件中;

workbook.SaveToFile("Data.xlsx",ExcelVersion.Version2007);

生成的excel文件效果图:

如何使用免费控件将Word表格中的数据导入到Excel中 

 

全部代码:

using System.Data;

using Spire.Xls;

using Novacode; //Docx

namespace word_table_to_excel

{

    class Program

    {

        static void Main(string[] args)

        {

            DocX document = DocX.Load("E:\\Program Files\\data.docx");

            Table table = document.Tables[0];

            DataTable dt = new DataTable("order");

            DataColumn column;

            for (int i = 0; i < table.ColumnCount; i++)

            {

                column = new DataColumn();

                column.ColumnName = table.Rows[0].Cells[i].Paragraphs[0].Text;

                dt.Columns.Add(column);

            }

            DataRow newRow;

            for (int i = 1; i < table.RowCount; i++)

            {

                newRow = dt.NewRow();

                Row row = table.Rows[i];

                for (int j = 0; j < table.ColumnCount; j++)

                {

                    newRow[j] = row.Cells[j].Paragraphs[0].Text;

                }

                dt.Rows.Add(newRow);

            }

            Workbook workbook = new Workbook();

            workbook.CreateEmptySheets(1);

            Worksheet sheet = workbook.Worksheets[0];

            sheet.InsertDataTable(dt, true, 1, 1);

            workbook.SaveToFile("Data.xlsx", ExcelVersion.Version2007);

        }

    }

}

总结:

这是两款独立的免费软件,使用时不需要安装MS Office。使我节省了不少的时间。如果你有好的意见或建议,希望可以在这里相互分享。

 

希望本文能给您带来一定的帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/109236.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 文本挖掘实例[通俗易懂]

    文本挖掘实例[通俗易懂]文本挖掘junjun2016年2月4日文本分析的应用越来越广泛,今天就讲讲关于评论数据的那点事。评论数据的获取:一般通过网络爬虫的方式抓取各大网站的评论数据,本次分析数据就来源于携程网某酒店的评论,成功爬取该酒店的评论数据,于是我开始使用这些数据做相关的分析。(注意:数据分析、挖掘时,这部分工作可以有专门的人员来完成)1、加载数据和包#1)本文使

  • postman支持rpc调用吗_跨域请求postman

    postman支持rpc调用吗_跨域请求postman平时我们做开发测试的时候,经常使用postMan做测试。最常用的是,测试http接口,其实RPC接口也是可以通过postman测试调用的。这里简单介绍一下:一、RPC接口说明二.POSTMAN调用{“jsonrpc”:”2.0″,”method”:”pushToClient”,”params”:[“aaa”,#第一个参数的值…

    2022年10月13日
  • MySQL中concat函数

    MySQL中concat函数

  • pycharm缩进设置_wps首行缩进快捷键

    pycharm缩进设置_wps首行缩进快捷键1、pycharm使多行代码同时缩进鼠标选中多行代码后,按下Tab键,一次缩进四个字符2、pycharm使多行代码同时左移鼠标选中多行代码后,同时按住shift+Tab键,一次左移四个字符Python语言是一款对缩进非常敏感的语言,给很多初学者带来了困惑,即便是很有经验的Python程序员,也可能陷入陷阱当中。最常见的情况是tab和空格的混用会导致错误,或者缩进不对,而这是用肉眼无法分别的…

  • 一笔画奇点偶点_一笔画图形奇点

    一笔画奇点偶点_一笔画图形奇点由一点引出的百线段为奇数个,则这个点为奇点。由一点引出的线段为偶数个,则这个点为偶点。一个图形判断能否被一笔画下来,关键是看奇点的个数:当奇点为0个或者2个时(不可能为一个,奇点都是成对出现),

  • python2.7安装pytorch_PyTorch安装「建议收藏」

    python2.7安装pytorch_PyTorch安装「建议收藏」这个系列写了好几篇文章,这是相关文章的索引,仅供参考:以下是相关深度学习工具包的安装,包括Tensorflow,PyTorch,Torch等:首先安装libcupti-devsudoapt-getinstalllibcupti-dev然后用virtualenv方式安装Tensorflow(当前是1.4版本)sudoapt-getinstallpython-pippython…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号