Skip to main content

A python library for reading and writing NBT files

Project description

Python-NBT

A python library for reading and writing NBT files. Compatible with json.

Based on NBT Version: 19133 (Current version used by Minecraft)

What is NBT

NBT (Named Binary Tag) is a tag based binary format designed to carry large amounts of binary data with smaller amounts of additional data. An NBT file consists of a single GZIPped Named Tag of type TAG_Compound.

From official Minecraft Wiki.

Usage

Read an NBT file

>>> import python_nbt.nbt as nbt
>>> file = nbt.read_from_nbt_file("file.nbt")

This function returns an instance of NBTTagCompound, or by the name on Minecraft Wiki, an instance of TAG_Compound. It only accept 1 argument, which can be either a file path string or an opened file stream.

The TAG_Compound acts like a dict in Python. More accurately, it is a subclass of dict in Python with some restrictions put on its keys and values. So you can get, and set its items as shown below:

>>> file['drop_loot_crates']
{'type_id': 1, 'value': 0}
>>> file['drop_loot_crates'] = nbt.TAG_Byte(1)
>>> file['drop_loot_crates']
{'type_id': 1, 'value': 1}

In the dict shown as above, the key 'type_id' represents the type id of an NBT. In our example, its 'type_id' is 1, which indicates this NBT is a TAG_Byte. And 'value' indicates its actual value.

Write an NBT file

Once you've completed editing an NBT, you can store it into an NBT file with the function below:

write_to_nbt_file(file, tag)

The first argument file should be a path string or a file stream to the file you want to create/write. The second argument tag is the NBT you want to write.

Compat with Json

If you want to export NBT in json, you can use NBTTagBase.json_obj to get an json style dict that contains all the NBT information. After that, you can use json module in Python to do whatever you want.

Note: Unable to import json format into NBT now, this feature is under developing

Future features

  • More json compat
    • Convert json into NBT
    • Better and configurable json output (omitting NBT types)
  • Convinient classes for reading mca files
    • World
    • Region
    • Chunk
  • Convinient classes for mods
    • FTB Quests

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

Python-NBT-1.0.1.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

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

Python_NBT-1.0.1-py3-none-any.whl (18.6 kB view details)

Uploaded Python 3

File details

Details for the file Python-NBT-1.0.1.tar.gz.

File metadata

  • Download URL: Python-NBT-1.0.1.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2 requests-toolbelt/0.9.1 tqdm/4.40.0 CPython/3.7.4

File hashes

Hashes for Python-NBT-1.0.1.tar.gz
Algorithm Hash digest
SHA256 ef1bdd18e49a0cec00332b2821c15318ddd06b6fa360dc3ce2f62b3cec174990
MD5 a57e288a3c82baa4d284452f9ed5353b
BLAKE2b-256 5072bcbd3fbb2e0f8c9f22805274e01b7b13780377c217d600e8f17718c75bc2

See more details on using hashes here.

File details

Details for the file Python_NBT-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: Python_NBT-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 18.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2 requests-toolbelt/0.9.1 tqdm/4.40.0 CPython/3.7.4

File hashes

Hashes for Python_NBT-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5fe95f0b2d47b88cdd4128447f17ed55bf7a6b967a8e62a5d972b0cdd64c8db5
MD5 b7a42d99b0525a3f5c1ceb551b2f171b
BLAKE2b-256 5c21e30e1d757c8138a1e48099b061bb71a5415cb505dfdccddd5ff294146a82

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