9

How can I get the labels in English or any other language in Wikidata by ID using SPARQL endpoint?

Franco Rondini
  • 10,841
  • 8
  • 51
  • 77
fattah.safa
  • 926
  • 2
  • 14
  • 36
  • 2
    this is how to use REST API: https://opendata.stackexchange.com/questions/5248/how-to-get-the-name-of-a-wikidata-item Not sure how to do this using SPARQL – Alexan Oct 26 '16 at 17:14

1 Answers1

15

Suppose wd:Q146190 is your wikidata entity ID

get the label in a specific language of your specific entity ID:

PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#> 
PREFIX wd: <http://www.wikidata.org/entity/> 
SELECT  *
WHERE {
        wd:Q146190 rdfs:label ?label .
        FILTER (langMatches( lang(?label), "EN" ) )
      } 
LIMIT 1

get all the labels in any language of your specific entity ID:

SELECT * WHERE {
  wd:Q146190 rdfs:label ?label 
}

here the link to the live try press on play to run the query then you could download a full JSON and get such a rensponse ..only a trunk copied here:

{
    "head": {
        "vars": [
            "label"
        ]
    },
    "results": {
        "bindings": [
            {
                "label": {
                    "xml:lang": "ar",
                    "type": "literal",
                    "value": "دوار الشمس الدرني"
                }
            },
            {
                "label": {
                    "xml:lang": "az",
                    "type": "literal",
                    "value": "Kökyumrulu günəbaxan"
                }
            },
          ..etc,etc.

get labels for each entity ID in a response resultset with multiple id

in this case you should use the Label service

SELECT ?p ?pLabel ?w ?wLabel WHERE {
   wd:Q30 p:P6/ps:P6 ?p .
   ?p wdt:P26 ?w .
   SERVICE wikibase:label {
    bd:serviceParam wikibase:language "en" .
   }
 }

to use this service add Label to the variable ( ie: for ?p label you must use ?pLabel then add

   SERVICE wikibase:label {
    bd:serviceParam wikibase:language "en" .
   }  

to the WHERE block

Franco Rondini
  • 10,841
  • 8
  • 51
  • 77