如何使用免费控件将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表格中. 虽然之前做过学生信息管理系 ...
随机推荐
- Python 爬虫4——使用正则表达式筛选内容
之前说过,使用urllib和urllib2,只是为了获取指定URL的html内容,而对内容进行解析和筛选,则需要借助python中的正则表达式来完成. 一.预备知识: 1.正则表达式简述: 什么是正则 ...
- (转)名称和本质 by王珢
名称和本质 by 王垠 我很喜欢 Richard Feynman 写的 <What Do You Care What Other People Think>.在最开头 Feynman 讲到 ...
- Probe在性能测试中的使用方式简介
简介: Lambda Probe(以前称为Tomcat Probe)是一款实时监控和管理的Apache Tomcat实例的基本工具. Lambda Probe 是基于 Web + AJAX 的强大的免 ...
- mysql 怎么通过sql语句批量去掉某一个表中某一个字段的多余字符
采用替换,把”<img src="“替换为空格," width="300" height="300" />也替换为空格,曾经在网 ...
- Xcode 改时间问题 lua代码没反应问题
Xcode 改时间问题 rm -fr $_TARGET_BUILD_CONTENTS_PATH/$1/*
- js 模版加载到前端
js 模版加载到前端 简单有效不高端 配个路由 /js/:filename , 用 readTemplate 响应请求,前端可以按模块方式直接 require 模板 'use strict' var ...
- 完美解决 Linux 下 Sublime Text 中文输入
首先,我参考了好几篇文章,都是蛮不错的,先列出来: sublime-text-imfix:首先推荐这个方法,最简单,但是在我的系统上有些问题.可用这个的强烈推荐用这个 完美解决 Linux 下 Sub ...
- window下搭建c开发环境(GNU环境的安装)
一.在windows平台上安装GNU环境 windows操作系统不自带GNU环境,如果需要开发跨平台的C语言程序,那么需要给windows安装GNU环境 windows下的两款GNU环境:MinGW和 ...
- iOS开发系列--UITableView全面解析
--UIKit之UITableView 概述 在iOS开发中UITableView可以说是使用最广泛的控件,我们平时使用的软件中到处都可以看到它的影子,类似于微信.QQ.新浪微博等软件基本上随处都是U ...
- CSS3 制作一个边框向周围散开的按钮效果
我们将要达到的是如下的效果(若效果未出现请刷新): 分析 主要还是运用CSS3的transition, animation, transform还有渐变背景等特性. 由于按钮在鼠标进入时有不同的样式, ...