C# 将excel表格嵌入到Word中

简介: C# 将excel表格嵌入到Word中 继续开扒,今天要实现的是使用C#将excel表格嵌入到Word中这个功能,将word表格导入到excel中我已经写过了,如有需要可参考我之前的文章,在开始前还有一点需要指出的是在我的这个示例中是将excel表格转换为图片,然后再嵌入至Word文档中。

C# 将excel表格嵌入到Word

继续开扒,今天要实现的是使用C#将excel表格嵌入到Word中这个功能,将word表格导入到excel中我已经写过了,如有需要可参考我之前的文章,在开始前还有一点需要指出的是在我的这个示例中是将excel表格转换为图片,然后再嵌入至Word文档中。

为了展示一下效果,我做了一个简单的excel表格,请看源excel工作表截图:

                       

下面看看如何使用代码:

第一步:新建一个Visual C#控制台项目,添加引用并使用如下命名空间:

using System.Drawing;
using Spire.Doc;
using Spire.Doc.Documents;
using Spire.Doc.Fields;
using Spire.Xls;

 

第二步:创建一个ConvertExcelToImage(string excelFile)方法,将excel的工作表转换为图片。 

static Image ConvertExcelToImage(string excelFile)
{
    //创建一个excel workbook对象
    Workbook workbook = new Workbook();
    //加载excel文件
    workbook.LoadFromFile(excelFile);
    //获取第一个工作表
    Worksheet sheet = workbook.Worksheets[0];
    //获取第一个工作表的最后一行
    int lastRow = sheet.LastRow;
    //获取第一个工作表的最后一列
    int lastColumn = sheet.LastColumn;

    //将第一个工作表转换为图片
    Image image = workbook.Worksheets[0].SaveToImage(1, 1, lastRow, lastColumn);
    return image;
}

 

第三步:在主函数内,新建一个word文档对象,并给它添加一个section和段落。

//新建一个word文档
Document doc = new Document();
//添加一个section
Section section = doc.AddSection();
//添加一个段落
Paragraph paragraph = section.AddParagraph();

 

第四步:获取excel文件的路径,新建一个DocPicture类的对象,调用ConvertExcelToImage()方法将excel工作表转换为图片并加载该图片。

string excelfile = "Customers.xlsx";
//新建一个DocPicture类的对象
DocPicture pic = new DocPicture(doc);
//将excel工作表转换为图片并加载
pic.LoadImage(ConvertExcelToImage(excelfile));

 

第五步:将图片嵌入到Word文档的段落中。 

paragraph.AppendOleObject("Customers.xlsx", pic, Spire.Doc.Documents.OleObjectType.ExcelWorksheet);

 

第六步:保存文档。

doc.SaveToFile("Output.docx", Spire.Doc.FileFormat.Docx); 

 

嵌入到word文档的效果图:

 

全部代码:

using System.Drawing;
using Spire.Doc;
using Spire.Doc.Documents;
using Spire.Doc.Fields;
using Spire.Xls; 

namespace Embed_Excel_to_Word
{
    class Program
    {
        static Image ConvertExcelToImage(string excelFile)
        {
            //创建一个excel workbook对象
            Workbook workbook = new Workbook();
           //加载excel文件
            workbook.LoadFromFile(excelFile);
            //获取第一个工作表
            Worksheet sheet = workbook.Worksheets[0];
            //获取第一个工作表的最后一行
            int lastRow = sheet.LastRow;
            //获取第一个工作表的最后一列
            int lastColumn = sheet.LastColumn;

            //将第一个工作表转换为图片
            Image image = workbook.Worksheets[0].SaveToImage(1, 1, lastRow, lastColumn);
            return image;
        }

        static void Main(string[] args)
        {
            //新建一个word文档
            Document doc = new Document();
            //添加一个section
            Section section = doc.AddSection();
            //添加一个段落
            Paragraph paragraph = section.AddParagraph();
            //获取excel文件的路径
            string excelfile = "Customers.xlsx";
            //创建一个DocPicture类的对象pic
            DocPicture pic = new DocPicture(doc);
            //将excel工作表转换为图片并加载
            pic.LoadImage(ConvertExcelToImage(excelfile));
            //将图片嵌入到word文档中
            paragraph.AppendOleObject("Customers.xlsx", pic, Spire.Doc.Documents.OleObjectType.ExcelWorksheet);

            //保存word文档
            doc.SaveToFile("Output.docx", Spire.Doc.FileFormat.Docx);
        }
    }
}

 

总结:

需要注意的是E-iceblue的excel和word组件是两个独立的组件,一起使用会起冲突抛出异常,因此这里我使用的是Office组件,也就是添加office组件里的excel和word相关的dll文件作为引用。

目录
相关文章
|
22天前
|
Java API Apache
Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
【10月更文挑战第29天】Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
90 5
|
16天前
|
SQL 数据可视化 数据挖掘
想让Excel表格设计更美观?试试这几款好用工具!
Excel表格设计在项目管理和数据分析中至关重要。本文推荐四款辅助工具:板栗看板、Excel自动图表助手、Think-Cell Chart 和 Power BI,分别在任务管理、图表生成、数据可视化等方面表现突出,帮助你设计出更专业、美观的表格。
35 2
|
24天前
|
XML C# 开发工具
C# 删除Word文档中的段落
【11月更文挑战第3天】本文介绍了两种方法来操作 Word 文档:一是使用 `Microsoft.Office.Interop.Word` 库,适用于 Windows 环境下操作 Word 文档,需引用相应库并在代码中引入命名空间;二是使用 Open XML SDK,适用于处理 .docx 格式的文档,通过引用 `DocumentFormat.OpenXml` 库实现。文中提供了示例代码,展示了如何打开、删除段落并保存文档。
|
29天前
|
JavaScript 前端开发 数据处理
Vue导出el-table表格为Excel文件的两种方式
Vue导出el-table表格为Excel文件的两种方式
|
2月前
|
SQL C# 数据库
EPPlus库的安装和使用 C# 中 Excel的导入和导出
本文介绍了如何使用EPPlus库在C#中实现Excel的导入和导出功能。首先,通过NuGet包管理器安装EPPlus库,然后提供了将DataGridView数据导出到Excel的步骤和代码示例,包括将DataGridView转换为DataTable和使用EPPlus将DataTable导出为Excel文件。接着,介绍了如何将Excel数据导入到数据库中,包括读取Excel文件、解析数据、执行SQL插入操作。
EPPlus库的安装和使用 C# 中 Excel的导入和导出
|
1月前
|
前端开发 JavaScript API
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
141 0
|
1月前
|
API C# Windows
【C#】在winform中如何实现嵌入第三方软件窗体
【C#】在winform中如何实现嵌入第三方软件窗体
96 0
|
1月前
|
Java Apache
Apache POI java对excel表格进行操作(读、写) 有代码!!!
文章提供了使用Apache POI库在Java中创建和读取Excel文件的详细代码示例,包括写入数据到Excel和从Excel读取数据的方法。
41 0
|
3月前
|
数据库
C#Winform使用NPOI获取word中的数据
C#Winform使用NPOI获取word中的数据
184 2
|
3月前
|
API C# 数据库
SemanticKernel/C#:实现接口,接入本地嵌入模型
SemanticKernel/C#:实现接口,接入本地嵌入模型
86 1