Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hanzhaoxin/ExcelReport
This reporting engine is built on NPOI.
https://github.com/hanzhaoxin/ExcelReport
Last synced: 4 months ago
JSON representation
This reporting engine is built on NPOI.
- Host: GitHub
- URL: https://github.com/hanzhaoxin/ExcelReport
- Owner: hanzhaoxin
- License: mit
- Created: 2015-01-18T08:48:59.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2020-10-20T08:15:13.000Z (over 4 years ago)
- Last Synced: 2024-11-01T01:45:58.907Z (4 months ago)
- Language: C#
- Size: 17.7 MB
- Stars: 619
- Watchers: 59
- Forks: 242
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- License: License.txt
Awesome Lists containing this project
- awesome-starred-test - hanzhaoxin/ExcelReport - This reporting engine is built on NPOI. (C# #)
README
# 快速入门
### ExcelReport是什么?
ExcelReport是一个Excel模板渲染引擎。 它基于关注点分离的理念,将数据与表格样式、字体格式分离。
其中模板承载的表格样式、字体格式在可视化的情况下编辑。开发人员只需要绑定数据与目标标签的对应关系。ExcelReport就可以以数据驱动的方式渲染出目标报表。
### 模块组成
data:image/s3,"s3://crabby-images/df09c/df09c9534c7a3f837cbc69aea0a86ea95c294e32" alt="image.png"
ExcelReport家族现在有四个成员。
ExcelReport负责报表的渲染逻辑。ExcelReport.Driver为ExcelReport提供了操作Excel文档的抽象接口。
ExcelReport.Driver.NPOI是使用NPOI对ExcelReport.Driver的实现。支持xls、xlsx两种格式的Excel文档。ExcelReport.Driver.CSV是针对csv格式的Excel文档对ExcelReport.Driver的实现。
### 渲染模型
data:image/s3,"s3://crabby-images/8e3ad/8e3ade20dd2e24d18ad7f7bac33e5e4773bea5f7" alt="image.png"
Template:模板承载的表格样式、字体格式、占位标签等。
Render:指定模板标签与数据的关系。
Data:注入模板的数据。整个渲染过程也是数据驱动渲染的。
Output:输出文件
### 入门示例
* 步骤一:新建入门项目QuickStart,并引入nuget包:data:image/s3,"s3://crabby-images/0ac7b/0ac7bbcd98ebaa8826a2c526794bbad43e6531da" alt="image.png"
data:image/s3,"s3://crabby-images/88b0a/88b0a8085e9aedd841e28843f0c169670ea4a1bc" alt="image.png"* 步骤二:创建并编辑模板
data:image/s3,"s3://crabby-images/70c87/70c872cd15df0333741057617de6ac5ec9dae51b" alt="image.png"
data:image/s3,"s3://crabby-images/6d31b/6d31bc12054a458a3caffca8a6ce49772901883d" alt="image.png"* 步骤三:编写代码
```csharp
internal class Program
{private static void Main(string[] args)
{
// 项目启动时,添加
Configurator.Put(".xlsx", new WorkbookLoader());var num = 1;
ExportHelper.ExportToLocal(@"templates\student.xlsx", "out.xlsx",
new SheetRenderer("Students",
new RepeaterRenderer("Roster", StudentLogic.GetList(),
new ParameterRenderer("No", t => num++),
new ParameterRenderer("Name", t => t.Name),
new ParameterRenderer("Gender", t => t.Gender ? "男" : "女"),
new ParameterRenderer("Class", t => t.Class),
new ParameterRenderer("RecordNo", t => t.RecordNo),
new ParameterRenderer("Phone", t => t.Phone),
new ParameterRenderer("Email", t => t.Email)
),
new ParameterRenderer("Author", "hzx")
)
);
Console.WriteLine("finished!");
Console.ReadKey();
}
}
``````csharp
public class StudentInfo
{
public string Name { get; set; }
public bool Gender { get; set; }
public string Class { get; set; }
public string RecordNo { get; set; }
public string Phone { get; set; }
public string Email { get; set; }
}
``````csharp
public static class StudentLogic
{
public static List GetList()
{
List list = new List();
list.Add(new StudentInfo() { Class = "一班", Name = "XXX01", Gender = true, RecordNo = "YYY0001", Phone = "158******01", Email = "[email protected]" });
list.Add(new StudentInfo() { Class = "二班", Name = "XXX02", Gender = false, RecordNo = "YYY0002", Phone = "158******02", Email = "[email protected]" });
list.Add(new StudentInfo() { Class = "一班", Name = "XXX03", Gender = true, RecordNo = "YYY0003", Phone = "158******03", Email = "[email protected]" });
list.Add(new StudentInfo() { Class = "一班", Name = "XXX04", Gender = true, RecordNo = "YYY0004", Phone = "158******04", Email = "[email protected]" });
return list;
}
}
```* 输出结果
data:image/s3,"s3://crabby-images/fc79e/fc79e8cf2b98a5596975aab2e40c1be9b3c2c066" alt="image.png"### 更多文章
[ExcelReport文档](https://www.yuque.com/motse/excelreport)### 相关用户组
[npoi users group](https://t.me/npoidevs)