ExcelCli 1.0.40
dotnet tool install --global ExcelCli --version 1.0.40
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local ExcelCli --version 1.0.40
#tool dotnet:?package=ExcelCli&version=1.0.40
nuke :add-package ExcelCli --version 1.0.40
ExcelToDotnet
Getting started
Nuget.org
https://www.nuget.org/packages/ExcelToDotnet/
introduce
English
Excel To Dotnet Compatible Data (Enum, Class, JSON)
It can be said to be a converter that can be used in Unity, C# applications, etc.
An Excel Sheet with a set rule is required.
In the case of Enum, only the Enum sheet must be registered. Otherwise, the sheet name becomes the class name.
In all cases, # is used as a comment (table, column, etc.).
In case of Enum, start :Begin and end point should be :End.
In the case of a table, the first row must be the column name, and the end point must be specified with :End. The second row is the data type, and it is possible to link to the Id column of another table with $.
Korean
Unity, C# 애플리케이션 등에서 사용할 수 있는 변환기입니다.
규칙에 맞게 입력된 Excel 시트가 필요합니다.
Enum의 경우 Enum 시트만 등록해야 합니다. 그렇지 않으면 시트 이름이 클래스 이름이 됩니다.
모든 경우에 #은 주석(테이블, 열 등)으로 사용됩니다.
Enum의 경우 시작 :Begin, 끝점은 :End여야 합니다. (:Begin은 -b 커맨드라인 명령으로, :End는 -r (행), -z (컬럼) 커맨드 라인 명령으로 재지정 가능합니다)
테이블의 경우 첫 번째 행은 열 이름이어야 하며 끝점은 :End로 지정해야 합니다. (:End는 -r (행), -z (컬럼) 커맨드 라인 명령으로 재지정 가능합니다)
두 번째 행은 데이터 타입으로 $로 다른 테이블의 Id 컬럼과 연결이 가능 합니다.
Excel Keyword Introduce (English)
Table Name (Sheet Name) Reserved Keyword
# (Comment)
comment or description
! (ignore)
ignore id column check
Data Type Reserved Keyword
# (Comment)
comment or description
! (ignore)
ignore type check (Custom DataType)
% (Percent)
It should be 100 when summing the row values. dataType double
$ (Reference)
Refers to the key of the sheet (table) of the string following $. (Error if associated value does not exist
~ (SubIndex)
cleanup & generate all option.
This is a function to check for duplicates within a table using the same index by placing a secondary index.
테이블명(시트명) 예약어
# 설명
코멘트 또는 설명
시트 변환을 시도하지 않고 참조용 페이지에서 사용해주세요.
! 무시하다
Id 컬럼 존재 여부 확인 무시
위와 같이 테이블명 (시트명)에 사용시, Id 컬럼에 대한 체크를 무시합니다.
Const{테이블명}
상수 값에 대한 기능으로, Id 컬럼에 대한 유효성 검사를 하지 않습니다.
위와 같이 Id 컬럼이 없어도 사용 가능합니다. ! 키워드와 동일한 동작입니다.
데이터 타입 예약어
# 설명
코멘트 또는 설명
행이나 열에 사용시, 해당 행이나 열은 모두 주석으로 인식됩니다.
! 무시하다
primitive type이 아닌, using을 통해 각종 내장 타입 혹은 외부 미리 선언된 타입을 사용하고자 할 경우 사용 (Custom DataType)
!Vector3 가 예시이며, Vector3를 System.Numerics.Vector3를 사용하기 위해서 ! 키워드를 앞에 붙임으로써, 타입 검사를 무효화 하는 기능입니다.
이 기능은 남발 할 경우, 서버나 클라이언트 컴파일 오류로 이어질 수 있으므로 주의 해야 합니다.
% 퍼센트
행 값을 합산할 때 100이어야 합니다.
행의 총 합을 계산해서, 100인지 아닌지를 검사하는 기능입니다.
$ 참조
$ 뒤에 오는 문자열의 시트(테이블)의 키를 참조합니다. (연결된 값이 해당 테이블에 없으면 오류)
특정 컬럼이, $이후에 쓰인 문자열에 해당하는 테이블에 존재하는지 확인하는 기능입니다.
예시는 Id 컬럼에 대해서 참조 값으로 사용했는데요, Id컬럼이 아닌 일반 컬럼에서도 사용 가능합니다.
~ 보조 인덱스
모든 옵션을 정리하고 생성합니다.
보조 인덱스를 배치하여 동일한 인덱스를 사용하는 테이블 내에서 중복 여부를 확인하는 기능입니다.
위 예시는 SubIndex가 같은 값인 행에 대해서, SubKey에 대해 중복 검사를 해준다는 의미입니다.
예를 들어, 특정 스테이지에 대한 보상을 지급 할 때, 동일한 스테이지에서는 동일한 보상을 선택하지 않게 하고 싶을 때 사용하시면 됩니다.
Sample Excel (xlsx)
https://github.com/elky84/ExcelToDotnet/blob/main/ExcelCli/Character.xlsx
add package
dotnet add package ExcelToDotnet
Implment CLI. (link ExcelToDotnet)
Release: https://github.com/elky84/ExcelToDotnet/releases
Reference : https://github.com/elky84/ExcelToDotnet/blob/main/ExcelCli/Program.cs, https://github.com/elky84/ExcelToDotnet/blob/main/ExcelCli
install cli global tool
require dotnet 6 (LTS) or later rumtime (also include rumtime in SDK) (https://dotnet.microsoft.com/en-us/download)
dotnet tool install -g ExcelCli
global tool usage
execute command name is excel2dotnet
use single excel file (-f)
excel2dotnet -f {fileName}
use target directory (-d)
excel2dotnet -d {directory}
use enum generate mode (-e)
excel2dotnet -d {directory} -e
use validation mode (-v)
excel2dotnet d {directory} -v
use nullable mode (-l) ⇒ for .NET 6 or later
excel2dotnet d {directory} -l
Execute CLI options (execute build file)
execute file name excel2dotnet
instead of ExcelCli
all options
Version History
v1.0.40
- upgrade Dotnet runtime version to 9.0
v1.0.39
- changes package structures.
- remove CodeGenerateExtend, CodeTemplate.
v1.0.38
- code fix for nullable rules.
- refactoring Generator.cs
v1.0.37
- upgrade Dotnet runtime version to 8.0
v1.0.36
- If it is a List type and contains an Enum, delete the condition that must not be Nullable.
v1.0.35
- Fix Probability validation error.
v1.0.34
- Check excel files only generate mode.
v1.0.33
- Modify DataTableEx's members to be non-nullable
v1.0.32
- removed string value Trim().
v1.0.31
- added string value Trim().
v1.0.30
- The added rule is that the list enum type must be Nullable.
v1.0.29
- fixed only string column validate id. (changes check all column type)
v1.0.28
- fixed tableName with ! (remove !) on validation mode.
- changed check probability sum by column.
v1.0.27
- added exception log on enum table empty string.
v1.0.26
- fixed tableName with ! (remove !)
v1.0.25
- fixed convert !Vector3, !Vector2 bug.
v1.0.24
- Fixed Validation Failed Exit Code. (0x0 → 0x4)
v1.0.23
- Support System.Numerics Vector2 and Vector3
v1.0.22
- Table EndsWith mark location to StartsWith.
v1.0.21
- support custom table type. (use with '!')
v1.0.20
- generate class to partial class
v1.0.19
- removed ignore mode
- added wide mode (cleanup & generate all option)
- fixed sub index, probability functions.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. |
This package has no dependencies.
Version | Downloads | Last updated |
---|---|---|
1.0.40 | 92 | 11/17/2024 |
1.0.39 | 123 | 5/29/2024 |
1.0.38 | 98 | 5/28/2024 |
1.0.36 | 228 | 12/28/2023 |
1.0.35 | 281 | 11/7/2023 |
1.0.34 | 242 | 11/7/2023 |
1.0.33 | 396 | 12/1/2022 |
1.0.32 | 410 | 10/29/2022 |
1.0.31 | 466 | 8/31/2022 |
1.0.30 | 440 | 8/24/2022 |
1.0.29 | 474 | 6/10/2022 |
1.0.27 | 438 | 6/5/2022 |
1.0.26 | 469 | 6/4/2022 |
1.0.25 | 503 | 4/21/2022 |
1.0.24 | 498 | 4/20/2022 |
1.0.23 | 519 | 4/20/2022 |
1.0.22 | 499 | 4/20/2022 |
1.0.20 | 531 | 2/21/2022 |
1.0.19 | 350 | 1/9/2022 |
1.0.18 | 319 | 1/5/2022 |
1.0.17 | 382 | 1/5/2022 |
1.0.16 | 309 | 1/5/2022 |
1.0.15 | 377 | 1/5/2022 |
1.0.14 | 330 | 1/5/2022 |
1.0.13 | 332 | 1/5/2022 |
1.0.12 | 354 | 1/5/2022 |
1.0.11 | 339 | 1/5/2022 |
1.0.10 | 364 | 1/3/2022 |
1.0.9 | 324 | 1/3/2022 |
1.0.8 | 297 | 1/3/2022 |
1.0.7 | 331 | 1/3/2022 |
1.0.6 | 336 | 1/3/2022 |
1.0.5 | 372 | 1/3/2022 |
1.0.4 | 320 | 1/3/2022 |