dotnet OpenXML 从文档生成创建文档的代码的库

93 篇文章 3 订阅
45 篇文章 5 订阅
本文介绍了Serialize.OpenXml.CodeGen库,该库可以从OpenXML文档(如Docx, PPTX, Xlsx)生成创建这些文档的C#或VB代码。通过这个开源库,用户可以基于模板文件自定义生成文档,并实现内容替换等功能。库代码托管在GitHub上,作者还分享了他的博客和QQ交流群,鼓励开发者交流和使用。" 105437245,9152529,数据库查询:从交叉连接到内连接的深入解析,"['数据库理论', 'SQL', '数据查询']
摘要由CSDN通过智能技术生成

本文和大家介绍 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:\Temp\Sample1.xlsx");
            var targetFile = new FileInfo(@"C:\Temp\Sample1.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/ 欢迎大家访问,里面有很多新的博客。只有在我看到博客写成熟之后才会放在csdn或博客园,但是一旦发布了就不再更新

如果在博客看到有任何不懂的,欢迎交流,我搭建了 dotnet 职业技术学院 欢迎大家加入

如有不方便在博客评论的问题,可以加我 QQ 2844808902 交流

知识共享许可协议
本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接:http://blog.csdn.net/lindexi_gd ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我联系

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值