TableML Excel编译/解析工具
TableML
TableML, Table Markup Language, 基于电子表格的标记语言,
类似JSON, XML, INI,TableML可以作为软件项目的配置标记语言,
与之不同的是,您可以使用Excel等电子表格编辑软件来配置TableML,自由地添加图标、注释、VB脚本和预编译指令,再由TableML编译器导出干净的TSV格式的配置表表格,编辑方便,使用简单。
目前提供C#版本的运行时、编译器、代码生成器。
感谢Mr.Kelly的开源项目,我基于Kelly的TableML基础,进行扩展增加或修改部分功能。
原始版本地址:https://github.com/mr-kelly/TableML
扩展版本地址:https://github.com/zhaoqingqing/TableML
Example
您可以使用Excel编译如下内容,并保存为文件setting/test.xls:
excel测试文件地址:https://github.com/zhaoqingqing/TableML/blob/custom/TableML/TableMLTests/TestSettings/TestExcel.xls
然后使用TableML命令行编译器:
TableML.exe --Src setting --To setting2 --CodeFile Code.cs
执行后,将会生成setting2/test.tml文件,打开可以看见编译后内容:
Id |
Value |
int |
string |
1 | Abcdefg |
2 | Yuiop |
另外附带一份Code.cs,自动生成的代码。
TableML编辑规则
以上的例子中,展示了TableML的大部分特性:
- TableML使用Excel等电子表格软件作为编辑器,并通过编译器导出成tml格式文件
- tml格式文件实质是TSV格式,即Tab Sperated Values,类似CSV
- 行头占3行:
- 第1行是列名
- 第2行是列的信息,通常是声明列的类型,可以自定义
- 第3行是列的注释
- 除外的所有行为内容
- 列名内容以#开头或Comment开头,改列被视为注释列,编译器忽略
- 行内容的第一个单元格内容,以#开头或Comment开头,改行被视为注释行,编译器忽略
- 可以使用预编译指令#if和#endif,条件式控制编译的行
工程使用说明
- 通过git clone 或者download master的方式将工程下载到本地
- 建议使用visual studio2012及更高版本打开 TableML\TableML.sln
- 在vs中设置TableMLCompilerConsole 为启动项目(解决方案面板,选中项目,右键 - 设为启动项目)
- 建议把项目的输出设为Release,然后选择 菜单栏 - 生成 - 生成TableMLCompilerConsole
- 打开目录 TableML\TableMLCompilerConsole\bin\Release 可以看到已经生成了TableML.exe
工程简介
TableML
- tml(tsv)文件读取接口,把tsv文件读取至内存,供应用程序访问
TableMLCompiler
- 对excel/csv 源文件进行编译,解析配置表规则生成tsv文件
TableMLCompilerConsole
- 提供命令行,根据条件对excel进行编译
TableMLGUI
- 提供GUI界面,增加编译选定excel,将数据导入到sqlite中
- 增加excel的查错,输出操作日志
- 更多介绍请查看:http://www.cnblogs.com/zhaoqingqing/p/7440867.html
TableMLTests
- 编译功能的单元测试
自定义配置
以下功能可以进行自定义或者是我扩展的功能:
1. 从第2列(指定列)开始读
修改SimpleExcelFile.cs中的StartColumnIdx值如:
public const int StartColumnIdx = 1;
2.每个表对应一个Class文件
调用方法如下:
batchCompiler.CompileTableMLAllInSingleFile(srcDirectory, OutputDirectory, CodeFilePath, templateString, "AppSettings", ".tml", null, true);
示例代码可参考:LocalDebug.cs中的CompileAll()
3.修改生成的代码模版
修改TableML.Compiler.DefaultTemplate中的字符串模版
4.预留指定行,自定义行,比如第6行是字段名,第8行是数据类型,第15行是字段注释
扩展SimpleExcelFile.PreserverRowCount = 预留行 修改SimpleExcelFile.ParseExcel中的Worksheet.GetRow();
excel读取规则
先读取Excel的行,再读取列,把数据写入到tml文件中。
GUI工具内存溢出
如果在使用TableMLGUI时,特别占用内存,建议把excel另存为csv格式,或者减少单个excel文件的大小,以减少内存占用。
更多功能
For SQL数据库
TableMLGUI提供一键将excel数据插入到sqlite中。
采用sql的事务机制,在插入大量数据的环境下,耗时更短。
同时在控制台输出sql语句方便调试查错。
自动读取配置代码生成
TableML编译器内置Liquid模板引擎。您可以自定义模板内容,来为不同的语言生成读表类。
TableML是KSFramework的一部分,用于游戏配置表读取代码,支持热重载、分表等机制。
TableML for C#/Mono/Xamarin
TableML目前只提供C#版本。当前TableML使用基于Xamarin Studio开发,TableML的C#版本具备了跨平台特性(Windows/Mac/Linux)。
TableML Excel编译/解析工具的更多相关文章
- TableML-GUI篇(Excel编译/解析工具)
项目情况 本文接上篇TableML Excel编译/解析工具,本文主要介绍GUI工具的使用,及配置项,如果你想了解此工具更加详细的说明,请阅读上篇文章. 项目地址:https://github.com ...
- TableML-GUI篇(C# 编译/解析 Excel/CSV工具)
项目情况 本文接上篇TableML Excel编译/解析工具,本文主要介绍GUI工具的使用,及配置项,如果你想了解此工具更加详细的说明,请阅读上篇文章. 项目地址:https://github.com ...
- Excel解析工具easyexcel全面探索
1. Excel解析工具easyexcel全面探索 1.1. 简介 之前我们想到Excel解析一般是使用POI,但POI存在一个严重的问题,就是非常消耗内存.所以阿里人员对它进行了重写从而诞生了eas ...
- 读取EXCEL文档解析工具类
package test;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException ...
- 自制 Word、Excel 批转 PDF 工具
原文:自制 Word.Excel 批转 PDF 工具 目前做金融业的项目,该公司每天会产生很多 Word.Excel 文档,需要大量地转换为 PDF,除了自己保存外,也要给金融主管机构作为备份.由于文 ...
- 一个基于POI的通用excel导入导出工具类的简单实现及使用方法
前言: 最近PM来了一个需求,简单来说就是在录入数据时一条一条插入到系统显得非常麻烦,让我实现一个直接通过excel导入的方法一次性录入所有数据.网上关于excel导入导出的例子很多,但大多相互借鉴. ...
- Java上传下载excel、解析Excel、生成Excel
在软件开发过程中难免需要批量上传与下载,生成报表保存也是常有之事,最近集团门户开发用到了Excel模版下载,Excel生成,圆满完成,对这一知识点进行整理,资源共享,有不足之处还望批评指正,文章结尾提 ...
- java使用POI进行 Excel文件解析
package com.timevale.esign.vip.util; import java.io.File; import java.io.FileInputStream; import jav ...
- excel模板解析—桥接模式:分离解析模板和业务校验
在做excel模板解析的时候,其实会有两个部分,第一,将模板读取出来,校验一些必录项等. 但除了这些,在数据真正被业务线使用的时候,还会有一些其他的校验,比如说:根据业务,年龄是不能超过多少岁的,包括 ...
随机推荐
- 浅谈字体小图标font awesome,iconfont,svg各自优缺点
三种都是矢量图(即放大不失真),但是个自又有个自的优缺点, 1.font awesome: 优点:相对比较简单,查看官网看例子基本上都会用 (http://www.bootcss.com/p/font ...
- [转载] 谷歌技术"三宝"之MapReduce
转载自http://blog.csdn.net/opennaive/article/details/7514146 江湖传说永流传:谷歌技术有"三宝",GFS.MapReduce和 ...
- KICKSTART无人值守安装 - (字符界面操作)
kickstart 部署 1.1 kickstart简介说明 1.1.1 pxe工作过程(图) 1.1.2 kickstart具体过程(图) 1.2 kickstart无人值守部署 1.2.1 系统环 ...
- [转]Oracle执行计划详解
Oracle执行计划详解 --- 作者:TTT BLOG 本文地址:http://blog.chinaunix.net/u3/107265/showart_2192657.html --- 简介: ...
- 魔方NewLife.Cube升级v2.0
魔方是一套集成权限管理的MVC管理后台,最具特色功能是模版覆盖机制,是XCode实体类的最佳搭档! v2.0.2017.1126 借助Ajax支持高级操作,如:删除选中.批量启用禁用等 用户管理增 ...
- LuaJavaBridge - Lua 与 Java 互操作的简单解决方案
http://dualface.github.io/blog/2013/01/01/call-java-from-lua/ 最近在游戏里要集成中国移动的 SDK,而这些 SDK 都是用 Java 编写 ...
- HTML5到底将给企业带来什么?
HTML5 是近年来互联网行业的热门词汇,火的很.有人高调宣称"APP 将在几年内灭亡,HTML5 取而代之" 改变企业网络广告的模式与分布 广告是企业网络营销的主要方式之一 十几 ...
- c语言的数组
1. 数组的基本概念 一个int类型的变量能保存一个人的年龄,如果想保存整个班的年龄呢? 1. 什么是数组 数组,从字面上看,就是一组数据的意思,没错,数组就是用来存储一组数据的 2. 数组的特点 ● ...
- XAMPP重要文件目录及配置
一.XAMPP 的安装过程 1:下载XAMPP 的 Linux 版 (1.7.4) http://www.apachefriends.org/en/xampp-linux.html#374 2:安装( ...
- js 数组去重复的方法
数组去重复是js中常用的方法,归纳了四种如下: 1. for + indexOf 去重复 var arr = [3,5,5,4,1,1,2,3,7,2,5]; var target = []; fo ...