ExcelToDotnet 1.0.40
dotnet add package ExcelToDotnet --version 1.0.40
NuGet\Install-Package ExcelToDotnet -Version 1.0.40
<PackageReference Include="ExcelToDotnet" Version="1.0.40" />
paket add ExcelToDotnet --version 1.0.40
#r "nuget: ExcelToDotnet, 1.0.40"
// Install ExcelToDotnet as a Cake Addin #addin nuget:?package=ExcelToDotnet&version=1.0.40 // Install ExcelToDotnet as a Cake Tool #tool nuget:?package=ExcelToDotnet&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. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net9.0
- CommandLineParser (>= 2.9.1)
- ExcelDataReader (>= 3.7.0)
- ExcelDataReader.DataSet (>= 3.7.0)
- Newtonsoft.Json (>= 13.0.3)
- System.CodeDom (>= 9.0.0)
- System.Text.Encoding.CodePages (>= 9.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.40 | 95 | 11/17/2024 |
1.0.39 | 132 | 5/29/2024 |
1.0.38 | 113 | 5/28/2024 |
1.0.37 | 187 | 12/28/2023 |
1.0.36 | 125 | 12/28/2023 |
1.0.35 | 184 | 11/7/2023 |
1.0.34 | 134 | 11/7/2023 |
1.0.33 | 341 | 12/1/2022 |
1.0.32 | 379 | 10/29/2022 |
1.0.31 | 395 | 8/31/2022 |
1.0.29 | 421 | 6/10/2022 |
1.0.27 | 416 | 6/5/2022 |
1.0.26 | 410 | 6/4/2022 |
1.0.25 | 460 | 4/21/2022 |
1.0.24 | 450 | 4/20/2022 |
1.0.23 | 426 | 4/20/2022 |
1.0.22 | 425 | 4/20/2022 |
1.0.21 | 435 | 4/20/2022 |
1.0.20 | 278 | 1/9/2022 |
1.0.19 | 283 | 1/9/2022 |
1.0.18 | 302 | 1/5/2022 |
1.0.16 | 291 | 1/5/2022 |
1.0.15 | 286 | 1/5/2022 |
1.0.10 | 304 | 1/3/2022 |
1.0.8 | 319 | 1/3/2022 |
1.0.7 | 306 | 1/3/2022 |
1.0.6 | 308 | 1/3/2022 |
1.0.5 | 284 | 1/3/2022 |
1.0.4 | 294 | 1/3/2022 |
1.0.3 | 305 | 12/27/2021 |
1.0.2 | 297 | 12/24/2021 |
1.0.1 | 299 | 12/24/2021 |
1.0.0 | 314 | 12/24/2021 |