Skip to main content

A python library to parse, edit, and save FTB snbt tag, which is a variant of the "vanilla" snbt tag.

Project description

ftb-snbt-lib

GitHub Release

A python library to parse, edit, and save FTB snbt tag.

FTB snbt tag is a variant of the "vanilla" snbt tag, which uses newline(\n) instead of comma(,) as separator.

This is the example of FTB snbt tag:

{
    some_tag: "some_value"
    another_tag: 1b
    list_tag: [
        "a"
        "b"
        "c"
    ]
}

This library works with both FTB snbt tag and the vanilla snbt tag. However, if you are finding the snbt library working perfectly for the "vanilla" snbt tag, use nbtlib by vberlier.

Installation

The package can be installed with pip.

$ pip install ftb-snbt-lib

Getting Started

  • Import the library.
>>> import ftb_snbt_lib as slib
  • load(fp): Load the ftb snbt tag from a file (fp).
    The type of returned value is Compound, a dictionary-like object.
    The Compound is containing values with tag data types provided by this library.
>>> some_snbt = slib.load(open("tests/some_file.snbt", "r", encoding="utf-8"))
>>> type(some_snbt)
<class 'ftb_snbt_lib.tag.Compound'>
>>> print(some_snbt)
Compound({'some_tag': String('some_value'), 'another_tag': Byte(1)})
  • dump(tag, fp, comma_sep=False): Dump the ftb snbt tag to a file (fp).
    If you set comma_sep parameter to True, the output snbt has comma separator ,\n instead of non-comma separator \n.
>>> slib.dump(some_snbt, open("tests/some_file_copy.snbt", "w", encoding="utf-8"))
# File Output:
# {
#    some_tag: "some_value"
#    another_tag: 1b
# }
>>> slib.dump(some_snbt, open("tests/some_file_copy.snbt", "w", encoding="utf-8"), comma_sep=True)
# File Output:
# {
#    some_tag: "some_value",
#    another_tag: 1b
# }
  • loads(s): Load the ftb snbt tag from a string s.
    The type of returned value is Compound.
>>> another_snbt = slib.loads('''
... {
...     some_tag: "some_value"
...     another_tag: 1b
... }
... ''')
>>> type(another_snbt)
<class 'ftb_snbt_lib.tag.Compound'>
>>> print(another_snbt)
Compound({'some_tag': String('some_value'), 'another_tag': Byte(1)})
  • dumps(tag, comma_sep=False): Dump the ftb snbt tag to a string.
    If you set comma_sep parameter to True, the output snbt has comma separator ,\n instead of non-comma separator \n.
>>> dumped_snbt = slib.dumps(another_snbt)
>>> print(dumped_snbt)
{
    some_tag: "some_value"
    another_tag: 1b
}
>>> dumped_snbt = slib.dumps(another_snbt, comma_sep=True)
>>> print(dumped_snbt)
{
    some_tag: "some_value",
    another_tag: 1b
}
  • Edit the snbt tag. As its type is Compound, it can be edited like a dictionary.
    The inserted or replace values should be any of tag data types provided by this library.
>>> another_snbt["some_tag"] = slib.String("another_value")
  • When editing the List, a list-like object, its elements must have the same type.
    For instance, List[Byte(1), Byte(2), Byte(3)] must contain only the Byte type object, so the other types like Integer or String cannot be added or replaced in it.

  • When editing the Array, a list-like object with a fixed length, its elements must have the same type, and that type must match the element type defined in the array.
    For instance, IntArray with a length of 3 must contain three Integer type objects, so adding new objects, removing existing objects, and replacing with other type objects are not allowed.

  • Save the edited snbt tag to a json file.

>>> import json
>>> json.dump(another_snbt, open("tests/test.json", "w", encoding="utf-8"), indent=4, ensure_ascii=False)

Data Types

Type Description Format Example
Byte A signed 8-bit integer.
Range: -128 ~ 127
<number>b 12b, -35b
Short A signed 16-bit integer.
Range: -32,768 ~ 32,767
<number>s 132s, -243s
Integer A signed 32-bit integer.
Range: -2,147,483,647 ~ 2,147,483,647
<number> 12345
Long A signed 64-bit integer.
Range: 9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807
<number>L 12345L
Float A 32-bit, single-precision floating-point number.
Range: -3.4E+38 ~ +3.4E+38
<number>f 12.345f, 1.0E-6f
Double A 64-bit, double-precision floating-point number.
Range: -1.7E+308 ~ +1.7E+308
<number>d 12.345d, 1.0E-6d
Bool A boolean data type.
0 for false, 1 for true.
false, true true
String A sequence of characters. A string enclosed in double quotes "".
Nested double quotes can be included within a string using a escaping character \".
"Hello, World!",
"Say \"Hello, World!\""
List An ordered list of tags.
The tags must be of the same type, determined by the first tag in the list.
Unnamed tags enclosed in square brackets and delimited by newline characters (\n).
[
3.2d
1.4d
...
]
Array An ordered list of 8-bit(ByteArray), 32-bit(IntArray), 64-bit(LongArray) integers. <array_prefix>; followed by an ordered list of tags enclosed in square brackets and delimited by newline characters (\n).
Valid array prefixes are B(Byte), I(Integer), and L(Long).
[B;
12b
-35b
...
]
Compound An ordered list of attribute-value pairs.
Each tag can be of any type.
Named tags enclosed in curly braces and delimited by commas or newline characters (\n).
The key (tag name) can be unquoted if it contains only 0-9, A-Z, a-z, _, -, ., and +. Otherwise the key should be quoted, using the format of String type.
[
tag1: "string"
tag2: 12b
"quoted:tag": 3.5d
...
]

References

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ftb_snbt_lib-0.4.1.tar.gz (58.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ftb_snbt_lib-0.4.1-py3-none-any.whl (58.9 kB view details)

Uploaded Python 3

File details

Details for the file ftb_snbt_lib-0.4.1.tar.gz.

File metadata

  • Download URL: ftb_snbt_lib-0.4.1.tar.gz
  • Upload date:
  • Size: 58.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ftb_snbt_lib-0.4.1.tar.gz
Algorithm Hash digest
SHA256 61d8d43dde0dbb5be0258f28aa734024c8c19c6c290beeb34c7874241bccf6c3
MD5 627d5705559ed4936d75481c3f7be7de
BLAKE2b-256 a7c2e87690ee1465e2ea458f621877b6bd87b0371fbd4b9c4387d795244908bf

See more details on using hashes here.

File details

Details for the file ftb_snbt_lib-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: ftb_snbt_lib-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 58.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ftb_snbt_lib-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e37bec6772195bd4d36e1f5d39d652725801cb114ac1233bbb859a451ec2f8e4
MD5 9c16a996408ed8eb8a2a072710bf4e3e
BLAKE2b-256 11b7a6115919dbdc9c01bfa660902d3e7e851121887187972da97af3a44936a4

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page