dotnet OpenXML 从文档生成创建文档的代码的库
本文和大家介绍 Serialize.OpenXml.CodeGen 这个支持从某个文档生成用于创建出这个文档的 C# 或 VB 代码的库。作用就是可以让小伙伴在拿到一份模版文件之后,可以通过 Serialize.OpenXml.CodeGen 生成能创建出这份文档的 C# 或 VB 的代码,用于在这份代码上面更改功能,做到创建定制 Docx 或 PPTX 或 Xlsx 文档的功能
这是一个完全开源的库,代码放在 https://github.com/rmboggs/Serialize.OpenXml.CodeGen 欢迎小伙伴访问
这个库的功能就是从 Office 文档里面,如 Excel 文档里面读取文档内容,生成 CodeCompileUnit 对象,通过 CodeCompileUnit 对象可以序列化为 C# 或 VB 代码
如从一个 xlsx 文件创建对应的 C# 代码,可以使用下面代码
假定在 C 盘有一个 Temp 文件夹,这个文件夹里面有一个 Sample1.xlsx 文件,在调用下面代码之后,将会创建了 Sample1.cs 文件
static void Main(string[] args)
{
var sourceFile = new FileInfo(@"C:TempSample1.xlsx");
var targetFile = new FileInfo(@"C:TempSample1.cs");
using (var source = sourceFile.Open(FileMode.Open, FileAccess.Read, FileShare.Read))
{
using (var xlsx = SpreadsheetDocument.Open(source, false))
{
if (xlsx != null)
{
var codeString = new StringBuilder();
var cs = new CSharpCodeProvider();
// This will build the CodeCompileUnit object containing all of
// the commands that would create the source code to rebuild Sample1.xlsx
var code = xlsx.GenerateSourceCode();
// This will convert the CodeCompileUnit into C# source code
using (var sw = new StringWriter(codeString))
{
cs.GenerateCodeFromCompileUnit(code, sw, Cgo);
}
// Save the source code to the target file
using (var target = targetFile.Open(FileMode.Create, FileAccess.ReadWrite))
{
using (var tw = new StreamWriter(target))
{
tw.Write(codeString.ToString().Trim());
}
}
}
}
}
Console.ReadKey();
}
上面代码的核心是 var code = xlsx.GenerateSourceCode();
可以将 Word 和 PPT 和 Excel 文档转换 CodeCompileUnit 对象,而 CodeCompileUnit 对象可以序列化为 C# 或 VB 代码
上面代码将创建 Sample1.cs 代码,这个代码可以通过 CreatePackage 方法向一个 Stream 里面写入 Sample1.xlsx 文档内容,而写入的方法是通过代码的形式,因此可以通过修改 Sample1.cs 代码定制写入的内容
例如我给的 Sample1.xlsx 只是一个模版,里面有很多内容可以替换,此时就可以修改 Sample1.cs 的代码,将可以替换的逻辑替换为自己的逻辑
本文代码放在github欢迎小伙伴访问
本文会经常更新,请阅读原文: https://blog.lindexi.com/post/dotnet-OpenXML-%E4%BB%8E%E6%96%87%E6%A1%A3%E7%94%9F%E6%88%90%E5%88%9B%E5%BB%BA%E6%96%87%E6%A1%A3%E7%9A%84%E4%BB%A3%E7%A0%81%E7%9A%84%E5%BA%93.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。
- 通过Nethogs查看服务器网卡流量情况
- 美国国会关于人工智能的提案
- update的多表更新的试验
- silverlight中如何得到ComboBox的选中值(SelectedValue)?
- kvm虚拟化管理平台WebVirtMgr部署-完整记录(安装ubuntu虚拟机)-(5)
- 从MapX到MapXtreme2004[9]-标注的强调显示
- 【第一季】Vue2.0内部指令
- 从MapX到MapXtreme2004[9]-标注的强调显示
- 分布式监控系统Zabbix-3.0.3-完整安装记录(4)-解决zabbix监控图中出现中文乱码问题
- 常用Lambda表达式实例
- centos6.8部署vnc服务
- linux下的缓存机制及清理buffer/cache/swap的方法梳理
- 分组合计且排序和显示名称
- silverlight动态读取txt文件/解析json数据/调用wcf示例
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法