概述

Spire是一套可以轻松处理Word、Excel和PDF的商业组件,需要收费,但是他有一套对应的免费组件FreeSpire可以使用,免费组件在功能上有一些限制(比如:excel的sheet数量不能超过30),对于普通应用来说大部分场景下都可以适用了。

中文帮助文档:帮助文档 | 全面丰富的在线文档,助您快速了解如何使用产品

本文代码基于Stylet开发,如果您还不了解Stylet,请参阅:

WPF优秀组件推荐之Stylet(一) - seabluescn - 博客园 (cnblogs.com)

WPF优秀组件推荐之Stylet(二) - seabluescn - 博客园 (cnblogs.com)

环境安装

在Nuget中搜索:FreeSpire

如果你只需要处理Excel或Word等,可以下载对应的包,怕麻烦可以下一个FreeSpire.Office的总包。(建议下载FreeSpire.Office,虽然文件多一些,但后期功能升级不需要再加组件,也不会有不同组件版本之间不兼容的问题)

生成Word文档

        public void SaveWord()
{
SaveFileDialog fileDialog = new SaveFileDialog()
{
Filter = "Word File(*.docx)|*.docx",
FileName = "Report01" + ".docx",
}; if (fileDialog.ShowDialog() == true)
{
Document document = new Document();
Section s = document.AddSection();
Paragraph para1 = s.AddParagraph();
para1.AppendText("欢迎使用Spire.Doc"); document.SaveToFile(fileDialog.FileName, Spire.Doc.FileFormat.Docx);
Process.Start(fileDialog.FileName);
}
}

生成Excel文档

        public void SaveExcel()
{
SaveFileDialog fileDialog = new SaveFileDialog()
{
Filter = "Word File(*.xlsx)|*.xlsx",
FileName = "Report01" + ".xlsx",
}; if (fileDialog.ShowDialog() == true)
{
Workbook workbook = new Workbook();
Worksheet sheet = workbook.Worksheets[0]; sheet.Range[1, 1].Text = "步骤";
sheet.Range[1, 2].Text = "时间"; int row = 2;
for (int i = 0; i <10; i++)
{
sheet.Range[row, 1].Text = i.ToString();
sheet.Range[row, 2].Text = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
row++;
} sheet.Range[row + 2, 1].Text = "报告时间:";
sheet.Range[row + 2, 2].Text = $"2022-02-02 11:11:11"; workbook.SaveToFile(fileDialog.FileName, ExcelVersion.Version2010);
Process.Start(fileDialog.FileName);
}
}

读取Word模板

生成Word文档时,格式其实很难控制,有一个简单的办法就是先创建一个模板格式文件,动态的内容先用特殊的占位字符串,然后程序再把相应的占位字符串给替换掉,这样文件的样式就可以非常容易调整和修改,客户有什么特殊需求还能直接修改模板,都不用改代码。

Code:

        public void LoadWord()
{
SaveFileDialog fileDialog = new SaveFileDialog()
{
Filter = "Word File(*.docx)|*.docx",
FileName = "Report02" + ".docx",
}; if (fileDialog.ShowDialog() == true)
{
Document document = new Document();
document.LoadFromFile(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Template", "WordTemplate.docx")); document.Replace("<$ReportTitle>", "报表标题", false, true);
document.Replace("<$CompanyName>", "公司名称", false, true); document.SaveToFile(fileDialog.FileName, Spire.Doc.FileFormat.Docx);
Process.Start(fileDialog.FileName);
}
}

生成Pdf文档

        public void SavePdf()
{
SaveFileDialog fileDialog = new SaveFileDialog()
{
Filter = "Word File(*.pdf)|*.pdf",
FileName = "Report01" + ".pdf",
}; if (fileDialog.ShowDialog() == true)
{
//初始化一个PdfDocument实例
PdfDocument document = new PdfDocument(); //设置边距
PdfUnitConvertor unitCvtr = new PdfUnitConvertor();
PdfMargins margins = new PdfMargins();
margins.Top = unitCvtr.ConvertUnits(2.54f, PdfGraphicsUnit.Centimeter, PdfGraphicsUnit.Point);
margins.Bottom = margins.Top;
margins.Left = unitCvtr.ConvertUnits(3.17f, PdfGraphicsUnit.Centimeter, PdfGraphicsUnit.Point);
margins.Right = margins.Left; //添加新页
PdfPageBase page = document.Pages.Add(PdfPageSize.A4, margins); //自定义PdfTrueTypeFont、PdfPen实例
PdfTrueTypeFont font = new PdfTrueTypeFont(new Font("宋体", 11f), true);
PdfPen pen = new PdfPen(Color.Black); //使用DrawString方法在指定位置写入文本
string text = "我的第一个C# PDF文档";
page.Canvas.DrawString(text, font, pen, 100, 50); //保存文档
document.SaveToFile(fileDialog.FileName);
Process.Start(fileDialog.FileName);
}
}

Word转换为PDF

Pdf的生成是比较麻烦的,更像是绘图操作,如果客户一定要Pdf格式报表,我一般先生成一个Word的临时文件,然后再转成pdf,当然Word的生成仍可以采用模板的方法。

        public void WordToPdf()
{
var WordFilePath = @"E:\Report02.docx";
var PdfFilePath = @"E:\Report02.pdf"; Document document = new Document();
document.LoadFromFile(WordFilePath);
document.SaveToFile(PdfFilePath, Spire.Doc.FileFormat.PDF);
Process.Start(PdfFilePath);
}

以上代码下载地址:NiceComponents · Bruce/Learn WPF - 码云 - 开源中国 (gitee.com)

本文只是演示了一些基本应用,表格、图片等都没有涉及,主要是官方文档已经非常详细了,更多高级功能请参考帮助文档。

WPF优秀组件推荐之FreeSpire的更多相关文章

  1. WPF优秀组件推荐之MahApps

    概述 MahApps是一套基于WPF的界面组件,通过该组件,可以使用较小的开发成本实现一个相对很好的界面效果. 官方网站:MahApps.Metro - Home 开源代码:MahApps · Git ...

  2. WPF优秀组件推荐之LiveCharts

    概述 LiveCharts是一个比较漂亮的WPF图表控件,在数据变化时还会有动画切换的效果,并且样式也可以控制. 官方网站:Live Charts (lvcharts.net) 开源代码:GitHub ...

  3. WPF优秀组件推荐之Stylet(一)

    一.简介 Stylet是基于WPF的一款MVVM组件,虽然WPF本身是自带MVVM功能的,但实现起来不是很方便 ,通过Stylet,用户可以用很少的代码就能享受MVVM带来的舒适体验. 目前Style ...

  4. WPF优秀组件推荐之Stylet(二)

    上一篇文章介绍了Stylet的一些基本功能,本篇将介绍一些深入一点的功能. 依赖注入 在Bootstrapper 类中注入需要的对象: public class Bootstrapper : Boot ...

  5. JS组件系列——Bootstrap组件福利篇:几款好用的组件推荐(二)

    前言:上篇 JS组件系列——Bootstrap组件福利篇:几款好用的组件推荐 分享了几个项目中比较常用的组件,引起了许多园友的关注.这篇还是继续,因为博主觉得还有几个非常简单.实用的组件,实在不愿自己 ...

  6. 优秀工具推荐:超实用的 CSS 库,样板和框架

    当启动一个新的项目,使用 CSS 框架或样板,可以帮助您节省大量的时间.在这篇文章中,我编译整理了我最喜欢的 CSS 样板,框架和库,帮助你在建立网站或应用程序时更加高效. 您可能感兴趣的相关文章 精 ...

  7. 【转】JS组件系列——Bootstrap组件福利篇:几款好用的组件推荐(二)

    前言:上篇 JS组件系列——Bootstrap组件福利篇:几款好用的组件推荐 分享了几个项目中比较常用的组件,引起了许多园友的关注.这篇还是继续,因为博主觉得还有几个非常简单.实用的组件,实在不愿自己 ...

  8. HP-Socket国产优秀socket通信组件推荐

    来源:http://blog.csdn.net/clb929/article/details/51085983 * HP-Socket 官方网站:http://www.jessma.org * HP- ...

  9. vue组件推荐

    Vue 是一个轻巧.高性能.可组件化的MVVM库,API简洁明了,上手快.从Vue推出以来,得到众多Web开发者的认可.在公司的Web前端项目开发中,多个项目采用基于Vue的UI组件框架开发,并投入正 ...

随机推荐

  1. 用了这么久 Linux ,才知道这些概念。。。

    Linux 和 UNIX 中的文件系统是一个以 / 为根的树状式文件结构,/ 是 Linux 和 UNIX 中的根目录,同样它也是文件系统的起点.所有的文件和目录都位于 / 路径下,包括我们经常听到的 ...

  2. 不使用pvc的方式在K8S中部署apisix-gateway

    不使用pvc的方式在K8S中部署apisix-gateway 简介 我的apisix使用etcd作为数据存储服务器,官方的使用pvc方式或者docker-compose的方式,对于新手不太友好,本篇是 ...

  3. JSP中的请求转发与重定向

    在说请求转发和重定向之前,得了解下JSP九大内置对象中的response和request response:将服务器端数据发送到客户端,可通过在客户端浏览器中显示,用户浏览页面的重定向以及在客户端创建 ...

  4. UITableViewCell的contentView

    contentView下默认有3个子视图其中2个是UILabel(通过UITableViewCell的textLabel和detailTextLabel属性访问)第3个是UIImageView(通过U ...

  5. Java基础复习(六)

    1. 接口的实现类中的实现接口中的抽象方法的方法必须为public,为什么? 接口中所有的方法与变量都默认是 public 的,在接口中可以不写出来.但在实现类中,如果不明写的话,就变成了 frien ...

  6. eclipse使用的步骤

    eclipse使用的步骤: 第一步: 选择工作目录. 以后在Eclipse上面写的所有代码都是在工作目录上的. 第二步: 在Project Exploer 窗口上创建一个工程,以后我们写代码都是以工程 ...

  7. iOS App程序内多语言国际化实现 By HL

    iOS 多语言设置有很多方式可以实现,之前在做手机思埠1.0时,就对app进行了多语言设置,当时看到很多方法,比如用plist等方式保存键值对的,不过还是用Localisator来国际化最方便 1.添 ...

  8. GRC: 个人信息保护法, 个人隐私, 企业风险合规治理

    声明 个人原创, 转载需注明来源 https://www.cnblogs.com/milton/p/15885344.html 个人信息保护的历史和现状 个人信息保护的立法可追溯至德国黑森州1970年 ...

  9. 流量录制与回放在vivo的落地实践

    一.为什么要使用流量录制与回放? 1.1 vivo业务状况 近几年,vivo互联网领域处于高速发展状态,同时由于vivo手机出货量一直在国内名列前茅,经过多年积累,用户规模非常庞大.因此,vivo手机 ...

  10. Solution -「ZJOI 2019」「洛谷 P5326」开关

    \(\mathcal{Description}\)   Link.   有 \(n\) 个开关,初始时所有开关的状态为 \(0\).给定开关的目标状态 \(s_1,s_2,\cdots,s_n\).每 ...