# 特点
```
(1) 简单易用,零学习成本
(2) 支持多种数据类型
(3) 支持Excel多行注释
(4) 强大的输入容错性
(5) 定位到单元格的错误提醒,更快的找出非法的输入
(6) 提供模板文件,可自定义输出的代码文件
(7) 支持文件缓存,提升导出速度
(8) 支持16进制输入
```
# 如何使用
命令行
```
ExcelToCode.exe
-excel_path Excel文件根目录[必填]
-code_path 代码文件导出目录[必填]
-data_path 数据文件导出目录[必填]
-cache_path 缓存文件存放目录[选填]
-template_path 模板文件目录[选填]
-data_suffix 数据文件后缀[选填]
```
准备好按格式填写好的Excel文件
data:image/s3,"s3://crabby-images/80b36/80b361888d551c7834fcd4aa1f9f20aca4a46ee8" alt=""
执行以下命令行即可在当前目录下生成Code和Data这两个文件夹,包含着代码文件和数据文件。
```
ExcelToCode.exe -excel_path ./Excel -code_path ./Code -data_path ./Data
```
data:image/s3,"s3://crabby-images/bbc60/bbc605f4f0cc39609d1d824b7262866a78fc89fe" alt=""
1个Excel导出1个代码文件和1个数据文件。
除了Excel导出的代码文件,还会额外导出一个Table.cs的代码文件
使用Table.cs来加载数据文件并使用。
例如UserInfo表
data:image/s3,"s3://crabby-images/8bfbf/8bfbf05b4f1ad4ae70cb047d2471b3eb9eaee73c" alt=""
导出的代码文件为`UserInfo.cs`
```C#
using System.Collections.Generic;
using Newtonsoft.Json;
namespace Feif
{
[JsonObject(MemberSerialization.OptIn)]
public class UserInfo
{
[JsonRequired] public string Name;
[JsonRequired] public int ID;
[JsonRequired] public string Sex;
[JsonRequired] public float Height;
[JsonRequired] public float Weight;
[JsonRequired] public long Birthday;
[JsonRequired] public string Flag;
}
}
```
数据文件为`UserInfo.json`
将导出的代码文件和数据文件复制到项目工程中
通过Table.Load函数加载数据文件,加载完成后就可以直接使用Table中数据
```C#
// 加载数据文件
Table.Load(File.ReadAllBytes("UserInfo.json"));
// 使用
var userInfos = Table.UserInfo;
foreach (var item in userInfos)
{
Console.WriteLine($"{item.ID} {item.Name} {item.Sex}");
}
```
# Excel填写要求
data:image/s3,"s3://crabby-images/8bfbf/8bfbf05b4f1ad4ae70cb047d2471b3eb9eaee73c" alt=""
```
(1) 第一行以#Class开头,后面接类名
(2) 第二行以#Field开头,后面接字段名
(3) 第三行以#Type开头,后面接类型
(4) 第四行以#Value开头,当前行和后面行填上数据
(5) 字符串类型必须写在""之间 ,且可使用转义字符\r \n \t \\ \" 等等
(6) 数组类型的分隔符为|。
(7) 字典类型的分隔符为:和|,:用来分隔key和value,|用来分隔不同的key-value
(8) 单元格不能为空,空字符串用""表示。
(9) byte,short,int,long,sbyte,ushort,uint,ulong支持16进制输入
```
以下是符合要求的填写示例,可参考源码文件中的Example
data:image/s3,"s3://crabby-images/63a49/63a49a689a5fed3992eed22757a2061d9198794a" alt=""
data:image/s3,"s3://crabby-images/576c1/576c14079826070de1cc2df88385b5024e47ad80" alt=""
data:image/s3,"s3://crabby-images/f7da5/f7da5ab6c5d7a7f501da4fd9bdd037790a13bcb7" alt=""
data:image/s3,"s3://crabby-images/a9eeb/a9eeb4dcc0d400786ee7f9688e66f865ff3ef3af" alt=""
data:image/s3,"s3://crabby-images/11510/115104739e1d2088d9368f2dadb99a29557748a1" alt=""
# 命名空间
(1) 支持在Excel中填写命名空间,导出的代码文件会包含填写的命名空间
(2) 可在ExcelToCode程序目中找到`setting.json`修改`DefaultNamespace`即可更改默认的命名空间
例如:#Class后填写Game.PlayerModel
data:image/s3,"s3://crabby-images/ba5df/ba5dff6c4afd4b153bcafbcfe3ae1aea97abf5a8" alt=""
data:image/s3,"s3://crabby-images/7da1f/7da1f63118b0e8e2ac6126003b702ceaac6afd71" alt=""
data:image/s3,"s3://crabby-images/7db9d/7db9dc741ba673a6b99c026ce0cb6c7f7b2cb997" alt=""
data:image/s3,"s3://crabby-images/2e250/2e250523b4d022c3164e75b4c1841f7d2008caba" alt=""
# 模板文件
```
使用-template_path来指定模板文件目录,不填将使用默认的模板文件。
默认模板文件在ExcelToCode程序文件夹下的Template。
分别为
(1)DataTemplate.txt
(2)DataFieldTemplate.txt
(3)TableTemplate.txt
(4)TableFieldTemplate.txt
替换的关键字有 #NAMESPACE# #PROPERTIES# #CLASS# #TYPE# #NAME#
注意:TableTemplate.txt模板文件的第一行要制定输出的文件名称。#FILENAME=Table#,将输出Table.cs。
```
# 支持的数据类型
11 + 11 + 11 + 11 * 11 = 154
11个基础类型 + 11个基础类型对应的数组类型 + 11个基础类型对应的集合类型 + 11个基础类型相互组合的字典类型 = 154
其他类型不支持,如:自定义类型、`List<List<int>>`、`Dictionary<int,List<float>>`等
```
int
float
double
long
byte
bool
uint
ushort
ulong
sbyte
string
List<int>
List<float>
List<double>
List<long>
List<byte>
List<bool>
List<uint>
List<ushort>
List<ulong>
List<sbyte>
List<string>
HashSet<int>
HashSet<float>
HashSet<double>
HashSet<long>
HashSet<byte>
HashSet<bool>
HashSet<uint>
HashSet<ushort>
HashSet<ulong>
HashSet<sbyte>
HashSet<string>
Dictionary<int,int>
Dictionary<int,float>
Dictionary<int,double>
Dictionary<int,long>
Dictionary<int,byte>
Dictionary<int,bool>
Dictionary<int,uint>
Dictionary<int,ushort>
Dictionary<int,ulong>
Dictionary<int,sbyte>
Dictionary<int,string>
Dictionary<float,int>
Dictionary<float,float>
Dictionary<float,double>
Dictionary<float,long>
Dictionary<float,byte>
Dictionary<float,bool>
Dictionary<float,uint>
Dictionary<float,ushort>
Dictionary<float,ulong>
Dictionary<float,sbyte>
Dictionary<float,string>
Dictionary<double,int>
Dictionary<double,float>
Dictionary<double,double>
Dictionary<double,long>
Dictionary<double,byte>
Dictionary<double,bool>
Dictionary<double,uint>
Dictionary<double,ushort>
Dictionary<double,ulong>
Dictionary<double,sbyte>
Dictionary<double,string>
Dictionary<long,int>
Dictionary<long,float>
Dictionary<long,double>
Dictionary<long,long>
Dictionary<long,byte>
Dictionary<long,bool>
Dictionary<long,uint>
Dictionary<long,ushort>
Dictionary<long,ulong>
Dictionary<long,sbyte>
Dictionary<long,string>
Dictionary<byte,int>
Dictionary<byte,float>
Dictionary<byte,double>
Dictionary<byte,long>
Dictionary<byte,byte>
Dictionary<byte,bool>
Dictionary<byte,uint>
Dictionary<byte,ushort>
Dictionary<byte,ulong>
Dictionary<byte,sbyte>
Dictionary<byte,string>
Dictionary<bool,int>
Dictionary<bool,float>
Dictionary<bool,double>
Dictionary<bool,long>
Dictionary<bool,byte>
Dictionary<bool,bool>
Dictionary<bool,uint>
Dictionary<bool,ushort>
Dictionary<bool,ulong>
Dictionary<bool,sbyte>
Dictionary<bool,string>
Dictionary<uint,int>
Dictionary<uint,float>
Dictionary<uint,double>
Dictionary<uint,long>
Dictionary<uint,byte>
Dictionary<uint,bool>
Dictionary<uint,uint>
Dictionary<uint,ushort>
Dictionary<uint,ulong>
Dictionary<uint,sbyte>
Dictionary<uint,string>
Dictionary<ushort,int>
Dictionary<ushort,float>
Dictionary<ushort,double>
Dictionary<ushort,long>
Dictionary<ushort,byte>
Dictionary<ushort,bool>
Dictionary<ushort,uint>
Dictionary<ushort,ushort>
Dictionary<ushort,ulong>
Dictionary<ushort,sbyte>
Dictionary<ushort,string>
Dictionary<ulong,int>
Dictionary<ulong,float>
Dictionary<ulong,double>
Dictionary<ulong,long>
Dictionary<ulong,byte>
Dictionary<ulong,bool>
Dictionary<ulong,uint>
Dictionary<ulong,ushort>
Dictionary<ulong,ulong>
Dictionary<ulong,sbyte>
Dictionary<ulong,string>
Dictionary<sbyte,int>
Dictionary<sbyte,float>
Dictionary<sbyte,double>
Dictionary<sbyte,long>
Dictionary<sbyte,byte>
Dictionary<sbyte,bool>
Dictionary<sbyte,uint>
Dictionary<sbyte,ushort>
Dictionary<sbyte,ulong>
Dictionary<sbyte,sbyte>
Dictionary<sbyte,string>
Dictionary<string,int>
Dictionary<string,float>
Dictionary<string,double>
Dictionary<string,long>
Dictionary<string,byte>
Dictionary<string,bool>
Dictionary<string,uint>
Dictionary<string,ushort>
Dictionary<string,ulong>
Dictionary<string,sbyte>
Dictionary<string,string>
```
data:image/s3,"s3://crabby-images/1f29a/1f29a3a90a69a8f1d40639a790f01f1784ccdc55" alt="avatar"
普通网友
- 粉丝: 1124
- 资源: 5294
最新资源
- 84105929555134世界网络收音机 .apk
- 【毕业设计】基于Python的Django-html人脸表情的分类算法的设计源码(完整前后端+mysql+说明文档+LW+PPT).zip
- 中移铁通操作手册.docx
- 【毕业设计】基于Python的Django-html人信息管理系统及安全策略分析系统源码(完整前后端+mysql+说明文档+LW+PPT).zip
- 狮子座12025年一定要.txt
- 【毕业设计】基于Python的Django-html深度学习文本相似度检测系统(bert)源码(完整前后端+mysql+说明文档+LW+PPT).zip
- 【毕业设计】基于Python的Django-html深度学习的web端多格式纠错系统源码(完整前后端+mysql+说明文档+LW+PPT).zip
- 【毕业设计】基于Python的Django-html图像取证技术研究与实现系统源码(完整前后端+mysql+说明文档+LW+PPT).zip
- 【毕业设计】基于Python的Django-html手写数字识别系统源码(完整前后端+mysql+说明文档+LW+PPT).zip
- 2025误差理论作业参考.zip
- 【毕业设计】基于Python的Django-html图像去雾算法研究系统源码(完整前后端+mysql+说明文档+LW+PPT).zip
- 【毕业设计】基于Python的Django-html图像信息隐藏技术设计源码(完整前后端+mysql+说明文档+LW+PPT).zip
- esp32配置 light-sleep 和 adc button 运行一段时间后系统重启
- 龙岩市乡镇边界,shp格式
- 宁德市乡镇边界,shp格式
- 景德镇市乡镇边界,shp格式
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
data:image/s3,"s3://crabby-images/64800/6480089faebe1b575565428f4b0911ff02baa1fa" alt="feedback"
data:image/s3,"s3://crabby-images/64800/6480089faebe1b575565428f4b0911ff02baa1fa" alt="feedback"
data:image/s3,"s3://crabby-images/8dc5d/8dc5db4e32f7fe0e912caf189022aff37cbe3642" alt="feedback-tip"