Data pack

The data pack system provides a way for players to further customize their Minecraft experience. Data packs can be used to override or add new advancements, dimensions, functions, loot tables, predicates, recipes, structures, tags, damage types, world generation settings, and biomes without any code modification.

Usage
Data packs can be placed in the .minecraft/saves/(world)/datapacks folder of a world. Each data pack is either a sub-folder or a .zip file within the datapacks folder. After it is in the folder, a data pack is enabled for that world when the world is reloaded or loaded.

Data packs load their data based on the load order. This order can be seen and altered by using the command and is stored in the  file.

The player can also select data packs at the world creation screen by clicking the Data Packs button and dragging-and-dropping their data pack folders/zip-files there. This is similar to the resource pack selection screen, and allows the player to enable data packs before the world is generated, and easily customize the load order too.

Folder structure
More than one directory for different namespaces may exist under the directory.

pack.mcmeta
A data pack is identified by Minecraft based on the presence of the pack.mcmeta file in the root directory of the data pack, which contains data in JSON format.


 * The root object.
 * Holds the data pack information.
 * A JSON text that appears when hovering over the data pack's name in the list given by the /datapack list command, or when viewing the pack in the Create World screen.
 * : Pack version. If this number does not match the current required number, the data pack displays a warning and requires additional confirmation to load the pack. See for a full list of pack format numbers.
 * : Section for filtering out files from data packs applied below this one. Any file that matches one of the patterns inside block will be treated as if it was not present in the pack at all.
 * : List of patterns
 * A regular expression for the namespace of files to be filtered out. If unspecified, it applies to every namespace.
 * A regular expression for the paths of files to be filtered out. If unspecified, it applies to every file.
 * A regular expression for the paths of files to be filtered out. If unspecified, it applies to every file.

pack.mcmeta, as used by the "vanilla" data pack in 1.19, as found in the client and official server jars:

data
This folder contains all the data under one or multiple namespaces. It can contain advancements, dimension, dimension_type, functions, loot_tables, predicates, recipes, structures, tags, chat_type, damage_type, and/or worldgen folders. The worldgen folder can contain biome, configured_carver, configured_feature, density_function, flat_level_generator_preset, noise, noise_settings, placed_feature, processor_list, structure, structure_set, template_pool and world_preset folders.

The dimension, dimension_type and worldgen folders are currently experimental features.

Each advancement, function, loot table, predicate, structure, recipe and tag file can be placed directly in their respective folder but sub-folders are also allowed.

Pack format
The table below describes the version range using each pack format number:

Template
The folder structure of the vanilla data pack: