ExcelCli 1.0.40

dotnet tool install --global ExcelCli --version 1.0.40                
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo
dotnet tool install --local ExcelCli --version 1.0.40                
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=ExcelCli&version=1.0.40                
nuke :add-package ExcelCli --version 1.0.40                

Website Made with Made with

Publish Nuget Github Package Publish Nuget Package Publish Nuget Tool Package

GitHub forks GitHub stars GitHub watchers GitHub followers

GitHub GitHub repo size in bytes GitHub code size in bytes

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.

테이블명(시트명) 예약어

# 설명

코멘트 또는 설명

excel_to_dotnet

시트 변환을 시도하지 않고 참조용 페이지에서 사용해주세요.

! 무시하다

Id 컬럼 존재 여부 확인 무시

excel_to_dotnet

excel_to_dotnet

위와 같이 테이블명 (시트명)에 사용시, Id 컬럼에 대한 체크를 무시합니다.

Const{테이블명}

상수 값에 대한 기능으로, Id 컬럼에 대한 유효성 검사를 하지 않습니다.

excel_to_dotnet

excel_to_dotnet

위와 같이 Id 컬럼이 없어도 사용 가능합니다. ! 키워드와 동일한 동작입니다.

데이터 타입 예약어

# 설명

코멘트 또는 설명

excel_to_dotnet

행이나 열에 사용시, 해당 행이나 열은 모두 주석으로 인식됩니다.

! 무시하다

primitive type이 아닌, using을 통해 각종 내장 타입 혹은 외부 미리 선언된 타입을 사용하고자 할 경우 사용 (Custom DataType)

excel_to_dotnet

!Vector3 가 예시이며, Vector3를 System.Numerics.Vector3를 사용하기 위해서 ! 키워드를 앞에 붙임으로써, 타입 검사를 무효화 하는 기능입니다.

이 기능은 남발 할 경우, 서버나 클라이언트 컴파일 오류로 이어질 수 있으므로 주의 해야 합니다.

% 퍼센트

행 값을 합산할 때 100이어야 합니다.

excel_to_dotnet

행의 총 합을 계산해서, 100인지 아닌지를 검사하는 기능입니다.

$ 참조

$ 뒤에 오는 문자열의 시트(테이블)의 키를 참조합니다. (연결된 값이 해당 테이블에 없으면 오류)

excel_to_dotnet

특정 컬럼이, $이후에 쓰인 문자열에 해당하는 테이블에 존재하는지 확인하는 기능입니다.

예시는 Id 컬럼에 대해서 참조 값으로 사용했는데요, Id컬럼이 아닌 일반 컬럼에서도 사용 가능합니다.

~ 보조 인덱스

모든 옵션을 정리하고 생성합니다.

보조 인덱스를 배치하여 동일한 인덱스를 사용하는 테이블 내에서 중복 여부를 확인하는 기능입니다.

excel_to_dotnet

위 예시는 SubIndex가 같은 값인 행에 대해서, SubKey에 대해 중복 검사를 해준다는 의미입니다.

예를 들어, 특정 스테이지에 대한 보상을 지급 할 때, 동일한 스테이지에서는 동일한 보상을 선택하지 않게 하고 싶을 때 사용하시면 됩니다.

Sample Excel (xlsx)

https://github.com/elky84/ExcelToDotnet/blob/main/ExcelCli/Character.xlsx

add package

dotnet add package 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

Version Downloads Last updated
1.0.40 95 11/17/2024
1.0.39 124 5/29/2024
1.0.38 99 5/28/2024
1.0.36 230 12/28/2023
1.0.35 283 11/7/2023
1.0.34 244 11/7/2023
1.0.33 398 12/1/2022
1.0.32 412 10/29/2022
1.0.31 468 8/31/2022
1.0.30 442 8/24/2022
1.0.29 476 6/10/2022
1.0.27 440 6/5/2022
1.0.26 471 6/4/2022
1.0.25 505 4/21/2022
1.0.24 500 4/20/2022
1.0.23 521 4/20/2022
1.0.22 501 4/20/2022
1.0.20 533 2/21/2022
1.0.19 351 1/9/2022
1.0.18 320 1/5/2022
1.0.17 383 1/5/2022
1.0.16 310 1/5/2022
1.0.15 378 1/5/2022
1.0.14 331 1/5/2022
1.0.13 333 1/5/2022
1.0.12 355 1/5/2022
1.0.11 340 1/5/2022
1.0.10 364 1/3/2022
1.0.9 325 1/3/2022
1.0.8 298 1/3/2022
1.0.7 332 1/3/2022
1.0.6 337 1/3/2022
1.0.5 373 1/3/2022
1.0.4 321 1/3/2022