Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >如何使用免费控件将Word表格中的数据导入到Excel中

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

作者头像
全栈程序员站长
发布于 2022-07-05 06:01:03
发布于 2022-07-05 06:01:03
4.6K00
代码可运行
举报
运行总次数:0
代码可运行

我通常使用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文档;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
DocX document = DocX.Load("E:\\Program Files\\data.docx");

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//获取文档的第一个表格

Table table = document.Tables[0];

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//创建一个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文档:

Datable:

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

代码片段:

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//创建一个Workbook示例

Workbook workbook = new Workbook();

//新建一个空的worksheet

workbook.CreateEmptySheets(1);

//获取第一个worksheet

Worksheet sheet = workbook.Worksheets[0];

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//将dataTable中的数据插入到worksheet中,1代表第一行和第一列

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
workbook.SaveToFile("Data.xlsx",ExcelVersion.Version2007);

生成的excel文件效果图:

全部代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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。使我节省了不少的时间。如果你有好的意见或建议,希望可以在这里相互分享。

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

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年9月1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Python自动化办公之Word,全网最全看这一篇就够了
使用Python操作word大部分情况都是写操作,也有少许情况会用到读操作,在本次教程中都会进行讲解,本次课程主要用到以下4个库,请大家提前安装。
Python小二
2020/11/24
2.6K0
Python自动化办公之Word,全网最全看这一篇就够了
asp.net core导入excel
对比昨天导出的内容增加了一行实体属性名称作为标题行,这样到转换为实体的时候才能找到对应的属性。
用户6362579
2019/09/29
9310
asp.net core导入excel
Python办公自动化 | 批量word报告生成工具
有时候我们需要按照某种规则生成一种固定模板的word报告,python能够很好的完成这项工作。本文通过一个小示例说明一下如何通过Python实现自动生成word报告。
披头
2020/01/14
8.8K1
Python办公自动化 | 批量word报告生成工具
C# 处理Word自动生成报告 四、程序处理
现在说一下程序处理部分,有点长 本来是想做针对doc和docx的模板两个版本, 后来想到可以在生成的时候saveas里设置格式, 所以此版只支持对docx的模板处理, 想要doc的情况可以选择生成格式为doc的. 上代码: public class WordHelper { private Word.Application wordApp = null; private Word.Document wordDoc = null; private D
FlyLolo
2018/05/17
2.1K0
再也不用复制粘贴了!自动读取Word文件并写入Excel
在做数据分析时,虽然操作docx并不是常用操作,但有些时候,数据分析师拿到的文件是docx或doc的Word文件,尤其是对数据具有至关重要的数据字典。接下来以一个数据字典为例来介绍下python-docx读取Word文件的基本操作。并将Word中的表格内容写入excel中。
数据STUDIO
2021/06/24
2.7K0
C# excel文件导入导出
在C#交流群里,看到很多小伙伴在excel数据导入导出到C#界面上存在疑惑,所以今天专门做了这个主题,希望大家有所收获!
zls365
2020/08/19
3.8K0
C# excel文件导入导出
C# NOPI 项目实战(经典)(可下载项目源码)
这篇文章主要介绍了如何安装NPOI,以及NPOI具体如何使用,并且用具体实例介绍了excel导入到datagridview以及 datagridview如何导出到excel并保存。如果不清楚这块的去我公众号去搜索这篇文章阅读。
zls365
2021/02/26
2.3K0
Excel导入导出数据库02
excel导入时还要保存字体、其背景颜色等信息时读取方法就要改变: 1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.IO; 6 using System.Data.OleDb; 7 using System.Data; 8 using Microsoft.Office.Interop.Excel; 9 u
欢醉
2018/01/22
4.4K0
C#导入Excel数据的方式(两种)
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/155377.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/06
6370
Word报告自动生成(例如 导出数据库结构)
        将很早之前写的一个小组件重新整理优化一下,做成一个通用的功能。适用于导出数据库的结构(表、字段等)到Word或将体检数据自动生成Word版的体检报告等。代码:Github
FlyLolo
2018/12/13
3.5K0
Word报告自动生成(例如 导出数据库结构)
python自动化办公——python操作Excel、Word、PDF集合大全
本文是鉴于有些粉丝的工作需求,有时候需要遇到这些文件的处理。因此,我写了一个文章集合,供大家参考,整篇文章已经整理成册(如下图所示)。由于文档获取人数太多,大家如有需求,请关注公众号:【数据分析与统计学之美】,回复关键词:【自动化文档】!
用户7886150
2021/01/24
1.9K0
原 高效读取Excel
原理 直接解析excel源文件,仅仅读取关心的数据,样式,公式,合并等等统统丢弃。 public class Option { /// <summary> /// 开始行 /// </summary> public int StartRow { get; set; } /// <summary> /// 结束行 /// </summary> public int EndRow { get; set; } public Option()
魂祭心
2018/05/17
8280
免费高效实用的.NET操作Excel组件NPOI(.NET组件介绍之六)
彭泽0902
2018/01/04
4.8K0
免费高效实用的.NET操作Excel组件NPOI(.NET组件介绍之六)
.Net之Nopi Excel数据导出和批量导入功能
  它是一个专门用于读写Microsoft Office二进制和OOXML文件格式的.NET库,我们使用它能够轻松的实现对应数据的导入,导出功能,并且还能通过其对应的属性对Excel进行对应的样式调整。是一个简洁而又强大的第三方库。
追逐时光者
2019/08/28
1.7K0
.Net之Nopi Excel数据导出和批量导入功能
Npoi导入导出Excel操作
    之前公司的一个物流商系统需要实现对订单的批量导入和导出,翻阅了一些资料,最后考虑使用NPOI实现这个需求。 在winform上面实现excel操作:http://www.cnblogs.com/CallmeYhz/p/4920293.html,NPOI的主页:http://npoi.codeplex.com/ 简介 NPOI 是 POI 项目的 .NET 版本。POI是一个开源的Java读写Excel、WORD等微软OLE2组件文档的项目, 使用 NPOI 你就可以在没有安装 Office 或者相应
用户1055830
2018/01/18
3.7K2
Npoi导入导出Excel操作
NPOI操作EXCEL
------------------------------------------------------------------------
zls365
2020/10/30
1.8K0
NPOI操作EXCEL
Python+Excel+Word一秒制作百份合同
今天我们继续分享一个真实的办公自动化需求:如何使Python+Excel+Word批量生成指定格式内容的合同。
刘早起
2020/08/12
2.5K0
Python+Excel+Word一秒制作百份合同
Qt Tablewidget表格数据的导出和导入
QT里面自带的TableWidget控件可以实现表格显示的功能,刚开始学习TableWidget,只是自己提前创建好表格,规定好数据,但真正的软件不会让我们规定好数据格式。下面我们一起来看一下,如何导入xls文件,自动生成表格。
花狗Fdog
2022/01/11
3.4K0
Qt Tablewidget表格数据的导出和导入
数据字典生成工具之旅(5):DocX组件读取与写入Word
根据文章内容为用户生成摘要总结。
用户1168362
2018/01/05
1.6K0
数据字典生成工具之旅(5):DocX组件读取与写入Word
C#使用NOPI导入Excel
附赠一个winform导入Excel的Demo。 https://github.com/yimogit/NopiExcelDemo
易墨
2018/09/14
1.4K0
推荐阅读
相关推荐
Python自动化办公之Word,全网最全看这一篇就够了
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验