如何使用免费控件将Word表格中的数据导入到Excel中
我通常使用MS Excel来存储和处理大量数据,但有时候经常会碰到一个问题—我需要的数据存储在word表格中,而不是在Excel中,这样处理起来非常麻烦,尤其是在数据比较庞大的时候,
这时我迫切地需要将word表格中的数据导入到Excel中。相信大家也碰到过同样的问题,下面我就给大家分享一下在C#中如何使用免费控件来实现这一功能。这里,我使用了两个免费API,
DocX和Spire.Xls。
有需要的朋友可以下载使用。下载地址:
DocX:codeplex官网
Spire.Xls: E-iceblue官网
注意:在创建项目后,需要添加这两个控件的相关.dll文件作为项目的引用。

以下是详细步骤:
首先我使用DocX API 来获取word表格中的数据,然后将数据导入System.Data.DataTable对象中。
代码片段:
步骤1:加载word文档;
DocX document = DocX.Load("E:\\Program Files\\data.docx");
步骤2:从文档中获取表格。作为示例,这里我仅获取了第一个表格;
//获取文档的第一个表格 Table table = document.Tables[];
步骤3:创建一个DataTable对象,并导入word表格中的数据;
//创建一个Datable对象并命名为order
DataTable dt = new DataTable("order");
//将word表格中的数据导入Datable
DataColumn column;
for (int i = ; i < table.ColumnCount; i++)
{
column = new DataColumn();
column.ColumnName = table.Rows[].Cells[i].Paragraphs[].Text;
dt.Columns.Add(column);
}
DataRow newRow;
for (int i = ; i < table.RowCount; i++)
{
newRow = dt.NewRow();
Row row = table.Rows[i];
for (int j = ; j < table.ColumnCount; j++)
{
newRow[j] = row.Cells[j].Paragraphs[].Text;
}
dt.Rows.Add(newRow);
}
效果图如下:
原word文档:

Datable:

其次,我使用了Spire.Xls API来创建一个Workbook对象,并将dataTable插入到Workbook中,然后将文件保存为.xlsx文件。
代码片段:
步骤1:创建一个Workbook实例并新建一个空的worksheet;
//创建一个Workbook示例 Workbook workbook = new Workbook(); //新建一个空的worksheet workbook.CreateEmptySheets(); //获取第一个worksheet Worksheet sheet = workbook.Worksheets[];
步骤2:将dataTable中的数据导入到worksheet;
//将dataTable中的数据插入到worksheet中,1代表第一行和第一列 sheet.InsertDataTable(dt, true, , );
步骤3: 保存到一个excel文件中;
workbook.SaveToFile("Data.xlsx",ExcelVersion.Version2007);
生成的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[];
DataTable dt = new DataTable("order");
DataColumn column;
for (int i = ; i < table.ColumnCount; i++)
{
column = new DataColumn();
column.ColumnName = table.Rows[].Cells[i].Paragraphs[].Text;
dt.Columns.Add(column);
}
DataRow newRow;
for (int i = ; i < table.RowCount; i++)
{
newRow = dt.NewRow();
Row row = table.Rows[i];
for (int j = ; j < table.ColumnCount; j++)
{
newRow[j] = row.Cells[j].Paragraphs[].Text;
}
dt.Rows.Add(newRow);
}
Workbook workbook = new Workbook();
workbook.CreateEmptySheets();
Worksheet sheet = workbook.Worksheets[];
sheet.InsertDataTable(dt, true, , );
workbook.SaveToFile("Data.xlsx", ExcelVersion.Version2007);
}
}
}
总结:
这是两款独立的免费软件,使用时不需要安装MS Office。使我节省了不少的时间。如果你有好的意见或建议,希望可以在这里相互分享。
希望本文能给您带来一定的帮助。
如何使用免费控件将Word表格中的数据导入到Excel中的更多相关文章
- 将页面中指定表格的数据导入到Excel中
function AutoExcel(){ var oXL = new ActiveXObject("Excel.Application"); //创建应该对象 var o ...
- Visual Basic 2012 借助DataGridView控件将SQL server2012 数据导入到Excel 2010
摘 要: SQL Server 2012 数据和Excel 2010之间的连接和数据的传输,本篇文章主要针对的是SQL Server 2012 数据导入到Excel 2010文件中.Excel软件对 ...
- Web打印控件Lodop实现表格物流单的打印
Web打印控件Lodop实现表格物流单的打印 一.lodop打印预览效果图 LODOP.PRINT_SETUP();打印维护效果图 LODOP.PREVIEW();打印预览图 二.写在前面 最近项目用 ...
- [Swift通天遁地]二、表格表单-(4)使用系统自带的下拉刷新控件,制作表格的下拉刷新效果
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- webbrowser控件显示word文档
参照某网站上的步骤(http://www.kuqin.com/office/20070909/968.html)首先,在Visual Studio中创建一个C#语言的Windows应用程序,然后在左侧 ...
- WPF 免费控件库
https://github.com/Infragistics/InfragisticsThemesForMicrosoftControls 几款WPF免费控件库,不过运行源码时需要下载三个DLL , ...
- 【2019V2全新发布】ComponentOne .NET开发控件集,新增.NET Core数据引擎
ComponentOne .NET开发控件集 2019V2正式发布,除持续完善并加入全新的.NET开发控件外,还针对产品架构稳定性.易用性.与.NET Core平台深度集成.已有控件功能增强等多个方面 ...
- 报表控件NCReport教程:集成NCReport到Qt应用程序中
NCReport是一款轻量级.快速.多平台.简单易用的基于Qt toolkit的C++编写的报表解决方案,目前主要包括报表渲染库和报表设计器GUI应用程序. 但是好多使用NCReport控件的朋友都不 ...
- 机房收费系统——在VB中将MSHFlexGrid控件中的数据导出到Excel
机房收费系统中,好多查询的窗体都包含同一个功能:将数据库中查询到的数据显示在MSHFlexGrid控件中,然后再把MSHFlexGrid控件中的数据导出到Excel表格中. 虽然之前做过学生信息管理系 ...
随机推荐
- ajax的理解与工作流程
一.什么是ajax ajax是一种异步通信技术.在ajax出现之前,客户端与服务端之间直接通信.引入ajax之后,客户端与服务端加了一个第三者--ajax.有了ajax之后,通过在后台与服务器进行少量 ...
- Webform Application传值 ViewState
Application:所有的会话共享一个Application空间,任何一个人改变Application的内容,其他人都会发现被改变了.Application中的内容不会被自动释放 存放位置:服务端 ...
- 新版 itextsharp pdf code
using System; using iTextSharp.text; using iTextSharp.text.pdf; using System.IO; namespace iTextShar ...
- 关于[super dealloc]
销毁一个对象时,需要重写系统的dealloc方法来释放当前类所拥有的对象,在dealloc方法中需要先释放当前类中所有的对象,然后再调用[super dealloc]释放父类中所拥有的对象.如先调用[ ...
- StartSSL免费SSL证书申请和账户注册完整过程
StartSSL算是比较早提供免费SSL证书的第三方提供商,我们可以免费申请且免费续期使用到有需要HTTPS网址的用户.关于网站使用SSL证书主要还是因为谷歌在向导说明中提到如果一个网站使用到SSL证 ...
- DPC和ISR的理解
首先来说中断 计算机的中断分为软中断和硬中断,即IRQL和DIRQL,共32个级别,从0~31级别依次提升,0~2属于软中断 一般线程运行于PASSIVE_LEVEL级别,如果不想在运行时切换到其他线 ...
- 设计一个用于人事管理的People(人员)类
#include <iostream> #include <string> using namespace std; class Date //日期类 { private: i ...
- C#_基础:排序算法
//希尔排序 static int[] ShellSort(int[] array) { if (array != null) { int[] list = { 9, 5, 3, 2, 1 }; fo ...
- 框架设计之ADO.NET Command的ExecuteScalar误用情景及底层解说
最近下载了点资料,学了学Android,发现Android入门还算简单,从.NET过渡到Android,也就三七十一天的事. 大伙有空也可以学学... 好了,言归正文,那日,有网友发了一个他们公司的数 ...
- 开发便于运维的Windows服务
过去几个月,DevOps on Windows网站推出了一系列文章,详细讲解了开发者应怎样创建便于运维的Windows服务.这一系列文章详细分析了如何克服在运维部门看来最困难的部分:Windows服务 ...