GitXplorerGitXplorer
t

godot-csv-data-importer

public
66 stars
7 forks
0 issues

Commits

List of commits on branch master.
Verified
7a0039958532c41f0746faa4a9153c96fb63528a

Add boolean detect (#4)

sshayaharuno committed 2 months ago
Unverified
4cd904ea1ce9e0c53cbe06ec2d3a828391fe001a

Fix error checking for FileAccess

ttimothyqiu committed 2 years ago
Verified
2dc4f694045b0ae8d75d91f99c627461153e6b25

Merge pull request #2 from clouds-game/master

ttimothyqiu committed 2 years ago
Verified
c8f5f63acc9e6dc75e1992a1f4a17347a0768507

fix _get_priority

cclouds56 committed 2 years ago
Unverified
e7acd87bbbbe95fae90831d33ca0a3e3daa5823e

Add examples

ttimothyqiu committed 2 years ago
Unverified
d2779eb9dd15f47f51de0ac2c41ce828b295b39d

Don't export readme files

ttimothyqiu committed 2 years ago

README

The README file for this repository.

Godot CSV Data Importer

MIT license 中文 README

Import CSV/TSV files as native Array or Dictionaries.

To install, download the ZIP archive, extract it, and move the addons/ folder it contains into your project folder. Then, enable the plugin in project settings.

To use this importer, select the CSV/TSV file, change Import As to "CSV Data" in the Import dock, set the import options and click Reimport.

The CSV/TSV file will be imported as a custom Resource object. Lines in the file will be turned into elements of an array named records on the object.

func _ready():
	var data = preload("res://example.csv")
	print(data.records)  # array of data

The type of array elements is determined by the import options. records is an array of string arrays by default.

Import Options

  • Delimiter
    • Use "Comma" for CSV and "Tab" for TSV.
  • Headers
    • Use the first line as header fields. Each element of records will be a Dictionary with header fields as keys.
  • Detect Numbers
    • Convert fields from string to int or float when possible.
  • Force Float
    • Always use float when detecting numbers.
  • Detect Booleans
    • Convert fields from string to false or true when case-insetively detecting according strings.

Example

After importing res://example.csv:

Apple,Banana,Cherry,Durian,Feijoa,Eggplant
-12,13,14.0,20.5,TRUE,False

The value of preload("res://example.csv").records will be:

# By default
[
	["Apple", "Banana", "Cherry", "Durian", "Eggplant", "Feijoa"],
	["-12", "13", "14.0", "20.5", "TRUE", "False"],
]

# With "Headers" enabled
[
	{
		"Apple": "-12",
		"Banana": "13",
		"Cherry": "14.0",
		"Durian": "20.5",
		"Eggplant": "TRUE",
		"Feijoa": "False",
	},
]

# With "Detect Numbers" and "Force Float" enabled
[
	["Apple", "Banana", "Cherry", "Durian", "Eggplant", "Feijoa"],
	[-12.0, 13.0, 14.0, 20.5, "TRUE", "False"],
]

# With Detect Booleans enabled
[
	["Apple", "Banana", "Cherry", "Durian", "Eggplant", "Feijoa"],
	["-12", "13", "14.0", "20.5", true, false],
]

# With "Detect Numbers" enabled, "Detect Booleans" enabled and "Force Float" disabled
[
	["Apple", "Banana", "Cherry", "Durian", "Eggplant", "Feijoa"],
	[
		-12,   # int
		13,    # int
		14.0,  # float
		20.5,  # float
		true,  # bool
		false, # bool
	],
]