Find an entity with the same score as another entity or player
Related: Check if a score is equal to, greater than, or less than another score
Java 1.13+ and Bedrock
[!NOTE] In bedrock edition use
c=
instead oflimit=
. The method that involves using predicates can not be replicated in bedrock
Method 1: Compare directly
For this method to work, we need to make sure that the entity that we want to compare to has to be unique in some way, so it can be found and is the only possible entity to result from its target selector. In this case we assume that it has been tagged with the compare
tag and is the only entity to have that. Furthermore, the objective we’re comparing is called points
.
execute as @a if score @s points = @e[tag=compare,limit=1] points run say I have the same points
This method works by changing the executor to all entities that need to be checked (in this case all players, @a
) and then using the execute if score
subcommand to check every executors score against the entities score.
Method 2: Store the score in a fake player first
This method has the advantage over the first one that it only need to evaluate the selector for the special entity once, but it has the disadvantage that it needs 2 commands. (what is a fake player?)
scoreboard players operation #fakeplayer points = @e[tag=compare,limit=1] points
execute as @a if score @s points = #fakeplayer points run I have the same points
When using a datapack, you can use this method for your Scoreboard ID system. One command copies the ID
score from the selected player to fake player #this ID
and the second adds the this
tag to the selected entity, so that in the following commands you can simply select all entities except this
entity. And after that you can easily select any entity that has the same ID
score in any target selector. At the end of the function you need to remove this
tag.
Below is an example of a function and predicate that selects an entity with the same ID
score as the selected player:
# funtion example:some_function (run as player)
scoreboard players operation #this ID = @s ID
tag @s add this
execute as @e[predicate=example:this_id,tag=!this] run say Some ID!
tellraw @s ["ID "{"selector":"@s"}," = ",{"selector":"@e[predicate=example:this_id,tag=!this]"}]
tag @s remove this
# predicate example:this_id
{
"condition": "minecraft:entity_scores",
"entity": "this",
"scores": {
"ID": {
"min": {
"type": "minecraft:score",
"target": {
"type": "minecraft:fixed",
"name": "#this"
},
"score": "ID"
},
"max": {
"type": "minecraft:score",
"target": {
"type": "minecraft:fixed",
"name": "#this"
},
"score": "ID"
}
}
}
}
Note: In addition, using predicate for the score comparison is preferable based on performance comparisons by u/sanscadre.
Method 3: Keeping the context through location
In this method we change the execution location to be the player(s) and the execution entity to be the entities to be compared to. That way @p
is all the players respectively and @s
is the entity to compare to. We can then get the player back into the execution chain using @p
.
execute at @a as @e if score @s id = @p id run ...
Java Pre-1.12
[!NOTE] This method also works in bedrock before new execute.
In bedrock this whole endeavour requires a few more commands, as execute doesn’t have any subcommands like that and /scoreboard players test
only allows for hardcoded ranges. Instead the way to go here is to remove the score from all the entities that need to be checked and then checking whether their score is 0.
Again, we’re assuming that the scoreboard objective you want to compare is called points
, that we want to find any player with the same score, and that the entity to compare to is the only entity tagged with compare
.
While we could just do the math operations on the original scores, we need to make sure to reset those afterwards if we want to keep the original scores around for one reason or another, so we’re going to use a temporary scoreboard objective that we store the value in and can modify it without affecting the original score. This temporary objective is assumed to be called pointsTmp
.
# first we copy the score to the new objective
execute @a ~~~ scoreboard players operation @s pointsTmp = @s points
# next we deduct the score of the special entity from everyones copy
execute @a ~~~ scoreboard players operation @s pointsTmp -= @e[tag=compare,c=1] points
# now we know that anyone with a copied score of 0 has the same score as the entity
execute @a[scores={pointsTmp=0}] ~~~ say I have the same score as the entity