In 1.13, the [if score ](https://minecraft.wiki/w/Commands/execute#(if |
unless)_score) execute subcommand makes this a lot easier. The syntax you’ll want is: |
execute if score <target> <targetObjective> (<|<=|=|>|>=) <source> <sourceObjective> run <command>
For example, to check if the executer’s kills
is greater than their deaths
:
execute if score @s kills > @s deaths run say I have more kills than deaths!
Or, to check if the nearest player’s money
score is equal to their cost
:
execute if score @p money = @p cost run <command>
You can also use matches
to check for a range if you want to always check for a given range and don’t want to store that in a different scoreboard:
execute if score @s diamonds matches 1..4 run say I have somewhere between 1 and 4 diamonds in my inventory.
execute if entity @s[scores={diamonds=1..4}] run say I have somewhere between 1 and 4 diamonds in my inventory.
To do this we must take one score from another, check if the score is now equal to/greater than/less than 0, then add the score back (to restore the first score’s original value).
For example, select all players whose kills
score is greater than their deaths
score:
Take everyone’s deaths
from their kills
execute @a ~ ~ ~ scoreboard players operation @s kills -= @s deaths
Select all players that now have a positive kills
score (so they had more kills than deaths)
say @a[score_kills_min=1]
Add everyone’s deaths
back to their kills
, to restore kills
original value
execute @a ~ ~ ~ scoreboard players operation @s kills += @s deaths
execute if score @p money matches 10.. run say I have 10 money or more.
Since version 1.20.5 can also compare values in storage directly, without copying values to scoreboard. Below is an example of using the minecraft:value_check
condition to compare values in storage.
# Example storage
data merge storage example:data {value:7.5f,min:0,max:10}
# predicate example:storage_compire
{
"condition": "minecraft:value_check",
"value": {
"type": "minecraft:storage",
"storage": "example:data",
"path": "value"
},
"range": {
"min": {
"type": "minecraft:storage",
"storage": "example:data",
"path": "min"
},
"max": {
"type": "minecraft:storage",
"storage": "example:data",
"path": "max"
}
}
}
This now allows to compare values more accurately because it supports non-integer variable values for comparison.
Since version 1.15 you can also use predicates in a datapack to compare scores. Unlike using the if score
subcommand, you cannot in most cases compare the score values between two entities. Basically this is only available in mob loot tables and you can only compare the score between the killed mob (this
) and the entity that killed the mob (killer
/ killer_player
), or the projectile that killed the mob (direct_killer
). In other cases, you can only check the score of the selected entity (this
) and score fakename.
You can compare score in a predicate using the minecraft:entity_scores
condition to compare the score of the selected entity with a specific value or a specified range of values, as well as using the minecraft:value_check
condition which does the same thing, but without using the entity.
But you can’t just use comparison operators (=, >, <, >=, <=), but only compare whether the value is in the specified range.
For entity_score
condition, you can compare the value of the selected entity with an exact value specified manually or a range (min
and max
). When using range can use for each min and max:
Example to compare that players score kills
>= score deaths
:
# execute if score @s kills >= @s deaths
{
"condition": "minecraft:entity_scores",
"entity": "this",
"scores": {
"kills": {
"min": {
"type": "minecraft:score",
"target": "this",
"score": "deaths"
}
}
}
}
For the <= operator, simply replace "min"
with "max"
in the predicate above.
But if you want to check that score kills
> deaths
, then checking in the predicate will be a little more complicated. So, we need to do two checks: first check that kills
>= deaths
, AND the second check is the inversion of the condition kills
<= deaths
.
# execute if score @s kills > @s deaths
[
{
"condition": "minecraft:entity_scores",
"entity": "this",
"scores": {
"kills": {
"min": {
"type": "minecraft:score",
"target": "this",
"score": "deaths"
}
}
}
},
{
"condition": "minecraft:inverted",
"term": {
"condition": "minecraft:entity_scores",
"entity": "this",
"scores": {
"kills": {
"max": {
"type": "minecraft:score",
"target": "this",
"score": "deaths"
}
}
}
}
}
]
If you need to check that kills
= deaths
score, then you can do one range check, where "min"
and "max"
are the same score.
# execute if score @s kills = @s deaths
{
"condition": "minecraft:entity_scores",
"entity": "this",
"scores": {
"kills": {
"min": {
"type": "minecraft:score",
"target": "this",
"score": "deaths"
},
"max": {
"type": "minecraft:score",
"target": "this",
"score": "deaths"
}
}
}
}