TemplateGO 1.1.1
dotnet add package TemplateGO --version 1.1.1
NuGet\Install-Package TemplateGO -Version 1.1.1
<PackageReference Include="TemplateGO" Version="1.1.1" />
paket add TemplateGO --version 1.1.1
#r "nuget: TemplateGO, 1.1.1"
// Install TemplateGO as a Cake Addin #addin nuget:?package=TemplateGO&version=1.1.1 // Install TemplateGO as a Cake Tool #tool nuget:?package=TemplateGO&version=1.1.1
TemplateGo
一款基于.NET Core的跨平台文档模板标记处理工具。
查找并替换文档中特殊标记,并支持图片、超链接、表格处理。
模板 | 数据 | 输出 |
---|---|---|
Hello ${name} | {name: "Alice"} | Hello Alice |
${home|link:content} | {home: "https://yanglb.com", content: "Home Page"} | Home Page |
${avatar|image:wf=2cm} | {avatar: "screenshots/avatar.jpg"} |
更多内容请参考下文
限制
- 暂不支持Word文档,今后有空时会添加Word模板处理。
- 对 Excel 公式支持还不够完整。
- 插入图片时位置及对齐方式还有些问题。
开始
安装
# 支持 Windows、Linux、MacOS
dotnet add package TemplateGO
使用
var templateFile = "{template file path}";
var jsonString = "{json data}";
TemplateRender.Render(templateFile, jsonString, "out.xlsx");
测试
git clone git@github.com:yanglb/template-go.git
cd template-go
dotnet build && dotnet test
# 测试结果:
ls -lh TemplateGOTests/out
文档
模板语法
${ property [| processor [| transform] [: options ]]}
property 属性路径
指示 TemplateGO 如何从JSON数据中获取要插入的内容。
property 为空字符串时直接返回 data 对象。
如下所示:
// data:
{
"name": "Alice",
"score": [{
"course": "physics",
"score": 85
}],
"school": {
"name": "北京大学",
"address": "北京市海淀区"
}
}
// property:
// name => Alice
// score[0].score => 85
// school.name => "北京大学"
// notExists => undefined
transform 转换器
在渲染前对数据进行处理。可添加多个转换器,多个转换器按标记块中出现的先后顺序执行。
示例
/// <summary>
/// 将 gender 转换为显示值
/// </summary>
/// <param name="value">male/female</param>
/// <param name="options">转换器选项</param>
/// <returns>性别友好值</returns>
private object? GenderTransform(object? value, TransformOptions options)
{
if (value == null) return null;
if (value.ToString() == "male") return "男孩";
if (value.ToString() == "female") return "女孩";
return "未知";
}
// data = {"name": "Alice", "gender": "female" }
TemplateRender.Render("template.xlsx", data, "out.xlsx", new TemplateOptions()
{
Transforms = new Dictionary<string, TransformDelegate>() {
{ "gender", GenderTransform },
}
});
// ${gender||gender} => 女孩
// ${gender|value|gender} => 女孩
processor 处理单元
指定数据处理单元,目前支持以下几种:
处理单元 | 作用 | 说明 |
---|---|---|
value (default) | 文字替换 | 默认 使用property属性值替换标记块。<br /> Excel: 如果单元格仅包含该标记块,则根据JSON数据类型自动设置单元格数据类型。 |
link | 超链接 | 将property所指内容视为链接地址,向文档添加超链接。 |
image | 图片 | 将property所指内容视为图片并插入到标记块所在位置。<br />支持本地文件、base64编码图片以及网络图片。 |
qr | 二维码 | 通过property所指内容生成二维码并插入到标记块所在位置。 |
table | 表格 | 向文档添加列表数据,property所指属性必需为数组。 |
value 文字替换
语法
${property | [|transform]} 或 ${property|value[|transform]}
其中value为默认处理单元,可省略。
示例
{"name": "Alice", "age": 18, "school": {}, "graduated": false }
标记块 | 输出 | 说明 |
---|---|---|
${name} | Alice | 单元格类型为 String |
${age} | 18 | 单元格类型为 Number |
Age: ${age} | Age: 18 | 单元格类型为 String |
${graduated} | FALSE | 单元格类型为 Boolean |
Is Graduated: ${graduated} | IS Graduated: FALSE | 单元格类型为 String |
${school} | [object Object] | TemplateGO 会将 JSON 中 Object或Array 转为 [object Object] 字符串。 |
${notExists} | JSON 中不存在的属性将不输出任何内容。 |
Excel: 如果单元格仅包含该标记块,则单元格数据类型将根据JSON数据设置。
link 超链接
语法
${property|link[|transform][:options]}
选项
名称 | 类型 | 默认值 | 说明 |
---|---|---|---|
content | String | 链接内容,如用英文引号("")包裹则视为字符串直接插入,否则将其当作属性key从JSON数据中获取。 |
- property 作为链接地址,如 https://yanglb.com
- content 作为链接显示内容,如 首页
示例
{"title": "Home Page", "url": "https://yanglb.com" }
标记块 | 输出 | 说明 |
---|---|---|
${url|link:title} | Home Page | 输出超链接 |
${url|link:"Test Page"} | Test Page | 输出超链接 |
My Home Page${url|link} | My Home Page | Excel 特有用法 Excel将超链接作用到单元格之上,因此整个单元格可点击。 |
image 图片
语法
${property|image[|transform][:options]}
选项
名称 | 类型 | 默认值 | 说明 |
---|---|---|---|
padding | String | 0 | 指定图片内边距,偏离所在单元格起始位置。 |
fw | String | 指定图片外框宽度。 | |
fh | String | 指定图片外框高度。 | |
deleteMarked | Boolean | false | 指示是否在插入图片后删除位于同一单元格之上的图片。<br />JSON中指定的图片不存在时不会删除。<br />主要用于在设计模板时添加样例或默认图片,但希望在生成的文档中优先使用JSON中的图片的场景。 |
padding/fw/fh 支持以下单位:
- cm 厘米
- in 英寸
- px 像素
外框及边距说明
fw/fh 并非控制图片尺寸,而是限制图片大小范围。
- 仅设置 fw 时图片宽度调整为 fw 值,高度按比例缩放。
- 仅设置 fh 时图片高度调整为 fh 值,宽度按比例缩放。
- 同时设置 fw/fh 时长边对齐,短边按比例缩放后居中对齐显示^1
示例
{
"file": "path-to-image",
"url": "https://raw.githubusercontent.com/yanglb/template-go/main/screenshots/avatar.jpg",
"base64": ""
}
标记块 | 输出 | 说明 |
---|---|---|
${url|image} | <br />(用于演示) | 将 url 中的图片插入到标记所在位置,且保持原始大小。 |
${file|image:padding=0.5cm, fw=2cm, fh=2cm} | <br />(用于演示) | 将 file 图片插入到标记所在单元格中,图片位于单元格左上角 0.5cm 处。<br />宽度或高度为2cm(长边=2cm 短边按比例缩放,并居中显示^1) |
${base64|image:deleteMarked} | <br />(用于演示) | 将 base64 内容做为图片插入到标记所在位置,如果base64不为空则删除原先在该位置的图片。 |
qr 二维码
语法
${property|qr[|transform][:options]}
使用property所指内容生成二维码图片,然后使用与 image 相同的行为插入到文档中。
选项、示例请参考 image
table 表格
仅支持在Excel中使用
语法
请在模板中按以下顺序设置:
- ${property|table[|transform][:options]} ⇒ 标记块
- columns ⇒ 列选项
- [title] ⇒ 标题行(可选)
- [sample] ⇒ 样例数据(可选)
- [other] ⇒ 其它内容(可选)
options 选项
名称 | 类型 | 默认值 | 说明 |
---|---|---|---|
titleCount | number | 1 | 标题行数量,默认为1。 |
sampleCount | number | 0 | 设计模板时添加的样本数据条数。当所在区域为表格时此选项无效。 |
limit | number | 不限制 | 限制最多插入数据条目数,默认为 property 所指数据的全部内容。 |
columns列选项
定义表格中每一列要插入的内容或属性名。
语法
column|processor[|transform][:options]
目前 processor 仅支持 value
column值 | 名称 | 处理器 | 转换器 | 示例 | 说明 |
---|---|---|---|---|---|
#index | 索引 | value | 支持 | 0 | 此列插入数组索引值,从0开始。 |
#seq | 序列 | value | 支持 | 1 | 此列插入数组序列值,从1开始。 #seq = #index + 1 。 |
#row | 行号 | value | 支持 | 1 | 此例插入行号。 |
#value | 值 | value | 支持 | "张三" | 此列插入数组值,用于插入非Object/Array类型的列表数据。 |
=formulaProperty | 公式属性 | value | 不支持 | =sumScore | 获取JSON数据中formulaProperty所指内容并作为公式插入到此列中。 |
=:formual | 字符公式 | value | 不支持 | =:SUM(表1[[#This Row],[语文]:[英语]]) | 将 formual 作为公式插入到此列中。 |
- | 留空 | 此列留空不插入任何内容。 | |||
property | 属性 | value | 支持 | name | 通过 property 属性获取数组中当前对象的值,并插入此列。 |
当插入字符公式时(=:formual)以下字符会替换为相应值
- #index
- #seq
- #row
title标题行
【可选】 可为表格添加由 titleCount 中设置数量的标题行。
sample样例数据
【可选】 可为表格添加由 sampleCount 中设置数量的样例数据,方便设计模板。
other其它内容
【可选】 可为表格添加其它内容,如汇总行等^2。
示例
模板
数据
{
"-": "以下数据为随机生成的测试数据,并非真实学生信息。",
"title": "三年二班学生成绩表",
"data": [
{"name": "贾阳煦", "language":85, "math":71, "english":84, "remark": "班长"},
{"name": "钟惠玲", "language":91, "math":61, "english":82},
{"name": "孟三春", "language":96, "math":81, "english":93},
{"name": "边念蕾", "language":81, "math":67, "english":85, "remark": "学习委员"},
{"name": "终苏凌", "language":95, "math":72, "english":70},
{"name": "勾融雪", "language":76, "math":99, "english":89},
{"name": "甄映寒", "language":62, "math":69, "english":80},
{"name": "濮高寒", "language":67, "math":90, "english":74},
{"name": "范弘致", "language":87, "math":79, "english":100},
{"name": "公冰洁", "language":73, "math":86, "english":86}
]
}
结果
License
Copyright (c) yanglb.com. All rights reserved.
Licensed under the MIT license.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net6.0
- DocumentFormat.OpenXml (>= 2.18.0)
- dotnetCampus.OpenXmlUnitConverter (>= 2.2.0)
- QRCoder (>= 1.4.3)
- SixLabors.ImageSharp (>= 2.1.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.