Shortcuts: WD:RAQ, w.wiki/LX
Wikidata:Request a query
Request a query This is a page where SPARQL queries [Q114898838] can be requested. Please provide feedback if a query is written for you. You can also request help to rewrite queries that don't work anymore, due to the WDQS graph split. For sample queries, see Examples and Help:Dataset sizing. Property talk pages include also summary queries for these. For help writing your own queries, or other questions about queries, see Wikidata talk:SPARQL query service/queries and Wikidata:SPARQL query service/query optimization. Help resources about Wikidata Query Service (Q20950365) and SPARQL: Wikidata:SPARQL query service/Wikidata Query Help and Category:SPARQL. To report an issue about the Query Service (interface, results views, export...) please see Wikidata:Contact the development team/Query Service and search. |
On this page, old discussions are archived. An overview of all archives can be found at this page's archive index. The current archive is located at 2024/11. |
Query for extracting tokens from a date string in various languages
[edit]I want to extract dates from a string in any language and for that I need a dictionary of words that represent days years or months. It currently has this format:
{ string: 'September', type: 'month', ordinal: 9, lang: 'en', }, { string: 'October', type: 'month', ordinal: 10, lang: 'en', }, { string: 'Sept', type: 'month', ordinal: 9, lang: 'en', }, { string: 'Septembers', type: 'month', ordinal: 9, lang: 'en', }, { string: '1st', type: 'day', ordinal: 1, lang: 'en', }, { string: '2nd', type: 'day', ordinal: 2, lang: 'en', }, { string: '3rd', type: 'day', ordinal: 3, lang: 'en', }, { string: 'Dezember', type: 'month', ordinal: 12, lang: 'de', }, { string: 'Dez.', type: 'month', ordinal: 12, lang: 'de', }, { string: '10月', type: 'month', ordinal: 10, lang: 'ja', }, …
I imagined that each entry is a form of a lexeme that has a sense pointing to a day of the month or month. I have an idea on how to get the forms but I don't know how to get all the sense-items (12 month names) plus day of a month (Q116600668). I'm aware that these may not have a lexeme yet. –Shisma (talk) 10:37, 27 October 2024 (UTC)
For better performance i decided to limit the query to specific languages. Do you see more potential for optimisation? –Shisma (talk) 14:04, 27 October 2024 (UTC)
Also I don't need plurals I think –Shisma (talk) 14:12, 27 October 2024 (UTC)
SELECT DISTINCT ?ordinal ?type ?string ?lang WHERE {
FILTER (?lang in ('en', 'de', 'ja'))
{
?thing wdt:P31 wd:Q47018901.
?thing wdt:P361 wd:Q12138.
BIND ('month' as ?type)
} UNION {
?thing wdt:P31 wd:Q116600668.
BIND ('day' as ?type)
}
?thing wdt:P1545 ?ordinal.
?sense wdt:P5137 ?thing.
?lexeme ontolex:sense ?sense.
?lexeme ontolex:lexicalForm ?form.
?lexeme dct:language ?language.
?language wdt:P218 ?lang.
?form ontolex:representation ?string.
}
Note to self: Due to recent changes by @Mullanur: this has to be changed to:
SELECT DISTINCT ?thing ?ordinal ?type ?string ?lang WHERE {
FILTER (?lang in ('en', 'ja'))
{
?thing wdt:P31 wd:Q47018901.
?thing wdt:P361 wd:Q12138.
BIND ('month' as ?type)
} UNION {
?thing wdt:P31 wd:Q116600668.
BIND ('day' as ?type)
}
FILTER NOT EXISTS { ?form wikibase:grammaticalFeature wd:Q146786 }
?thing p:P31 ?instanceOf.
?instanceOf pq:P1545 ?ordinal.
?sense wdt:P5137 ?thing.
?lexeme ontolex:sense ?sense.
?lexeme ontolex:lexicalForm ?form.
?lexeme dct:language ?language.
?language wdt:P218 ?lang.
?form ontolex:representation ?string.
}
*the series ordinal was moved to be a qualifier of the instance of statement –Shisma (talk) 10:12, 5 November 2024 (UTC)
Howto dynamically create a Point() ?
[edit]I have a federated query, and I'm stuck at the point where I have latitude and longitude data from an external service. Next, I would like to calculate the distance from these latitude and longitude coordinates to a specific Wikidata item. However, I am unsure how to convert them into a Point() format that can be used with geo:distance(). A simplified example of the query I'm trying to get working is shown below. Do you know how this should be done?
SELECT ?place ?location ?distance WHERE {
?place wdt:P625 ?location .
BIND(-122.402251 as ?lat) .
BIND(37.789246 as ?lon) .
# BIND("Point(?lat ?lon )"^^geo:wktLiteral as ?location2) "DOESNT WORK
BIND("Point(-122.402251 37.789246)"^^geo:wktLiteral as ?location2) # WORKS
BIND(geof:distance(?location, ?location2) AS ?distance)
} LIMIT 3
--Zache (talk) 11:59, 29 October 2024 (UTC)
- Try:
- Try it!
SELECT ?place ?location ?distance WHERE { ?place wdt:P625 ?location . BIND(-122.402251 as ?lat) . BIND(37.789246 as ?lon) . BIND(STRDT(CONCAT( 'Point(', str(?lat), ' ', str(?lon), ')' ), geo:wktLiteral) as ?location2) # NOW WORKs # BIND("Point(-122.402251 37.789246)"^^geo:wktLiteral as ?location2) # WORKS BIND(geof:distance(?location, ?location2) AS ?distance) } LIMIT 3
- To unpack that BIND() line, firstly
?lat
and?lon
need to appear as variables in the expression, not as literal strings. But we need to usestr()
to turn them from numeric values to string values. Then we need to use CONCAT() to assemble them into the Point(...) string. And then I have used STRDT() to promote the string to the right data-type, which is like the ^^ that you had, but works with expressions rather than just literal strings.
- Hope this helps, Jheald (talk) 12:23, 29 October 2024 (UTC)
Fetching subclasses
[edit]Hi. I'm trying to write a query which fetches all items that link to the WWI item which also have a statement that is, or is subclass of, Surrey (historic county and county). The closest ive got is this but I cannot figure out why it's not fetching the subclasses of items. Can anyone help? Cheers Jason.nlw (talk) 09:36, 1 November 2024 (UTC)
- @Jason.nlw: I think your
wdt:P31|wdt:P279
is the problem. You has to writewdt:P31/wdt:P279
. When I change this, then your query run into "OutOfMemory"-Error. Can you write your query more specific? Like only people or only places. Best regards. --sk (talk) 08:45, 2 November 2024 (UTC) - @Jason.nlw Being a subclass of a country does not make sense. A class is (usually) a type of real world object you can regroup according to some criteria. Real world objects, specific examples, are said to be "instances of" (P31) a class. For example Surrey is an instance of county, an as it is a real world example it cannot have instances.
- You might want things that are "part of" (part of (P361)) or located in (location (P276) ) Surrey? author TomT0m / talk page 10:38, 2 November 2024 (UTC)
- Thanks @Stefan Kühn and @TomT0m. Yeah I had the whole 'subclass of Surrey' thing confused. I rewrote those bits with P131* and the query now works as required. Thanks for your help! Jason.nlw (talk) 08:18, 4 November 2024 (UTC)
Get all pages edited in the last month in all subcategories of mathematics
[edit]Hi. How can I get all pages edited in the last month in all subcategories of mathematics. Thanks Andresv.63 (talk) 06:09, 4 November 2024 (UTC)
- There isn't many items that are classified as mathematics, but here's a query for items edited last month that are related to mathematics: https://w.wiki/Bp$Y . If you meant pages on Wikipedia (the english one in this example) just use Petscan for that: https://petscan.wmcloud.org/?psid=29725855 Infrastruktur (talk) 11:45, 4 November 2024 (UTC)
- @Infrastruktur
- Thank you. Petscan gives almost the solution I want. In any case, I want a query to then add things: user, not my pages, pages written in many languages but not mine, etc...
- I would like to get that just like Petescan searches in 5 subcategories below mathematics to be able to do that in a Wikidata Query Service query
- Andresv.63 (talk) 15:56, 4 November 2024 (UTC)
Movies taken in a city
[edit]Hi, I have Property:P915 which denotes the place where a film was shot. This may be a city, a part of a city, a park, a building... Almost anything. How can I query all the films that were shot e.g. in Paris? Bináris (talk) 09:05, 4 November 2024 (UTC)
- @Bináris: something like that :
select distinct ?film ?filmLabel {
?film wdt:P915/(wdt:P276| wdt:P131 )* wd:Q90
SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],mul,en". }
}
- author TomT0m / talk page 11:23, 4 November 2024 (UTC)
- @Bináris
- Try it!
#defaultView:Map,Table SELECT distinct ?item ?itemLabel ?itemDescription ?regionLabel ?coordinate WITH { SELECT distinct ?region # get all subregions WHERE { hint:Query hint:optimizer "None" . BIND(wd:Q90 AS ?state). # of a region (Paris) ?region wdt:P131* ?state. #MINUS { ?region wdt:P576 _:b0. } # no dissolved regions } } AS %region WHERE { INCLUDE %region. ?item wdt:P915 ?region. # filming location OPTIONAL {?region wdt:P625 ?coordinate.} # coordinate SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE]". } } order by ?itemLabel
- With this query you get also all subregions of Paris. So you get 1317 films. Also as map or table. Best regards --sk (talk) 17:20, 4 November 2024 (UTC)
- Great, thank you! Now I have to guess how to transform this to Pywikibot... Bináris (talk) 10:30, 5 November 2024 (UTC)
- @Stefan Kühn This seems to be the same as my query, so you get the same films, except you have duplicate results because I don't get the place and they are likely to be filmed in several locations in Paris. 1317 films is not correct, I think the number of film is still 965.
- @Bináris What do you want to do with those ? If you like we can get the titles of the movie page on a Wikipedia for easier use with pywikibot. (something like including
?article schema:isPartOf <https://en.wikipedia.org> ; schema:name ?title; schema:about ?film.
- that would get : 640 results on enwiki. author TomT0m / talk page 12:25, 5 November 2024 (UTC)Try it!
select distinct ?name { ?film wdt:P915/(wdt:P276| wdt:P131 )* wd:Q90 . ?article schema:isPartOf <https://en.wikipedia.org/> ; schema:name ?name; schema:about ?film. }
- Thank you. Duplications are no problem, and the exact places are an advantage. Whereever I travel in the world, I want to know where are these locations and what films are related to that very place. Wikipedias where they have articles are not important, that's why I want to use Wikidata. Bináris (talk) 08:02, 6 November 2024 (UTC)
- Pywikibot makes sense to get the results for a journey automatically. Bináris (talk) 08:03, 6 November 2024 (UTC)
- @Bináris I don't see how you need pywikibot for this ?
- If you want which film is "related" you might also want to use narrative location (P840) as well, as a a film may not be shot at the location the action is supposed to take place. author TomT0m / talk page 09:30, 7 November 2024 (UTC)
- Yes, I know, thank you. I want to create lists automatically for a bunch of sities. Pywikibot is much more comfortable for me, than run a query each time manually. Bináris (talk) 11:45, 8 November 2024 (UTC)
- Pywikibot makes sense to get the results for a journey automatically. Bináris (talk) 08:03, 6 November 2024 (UTC)
- Thank you. Duplications are no problem, and the exact places are an advantage. Whereever I travel in the world, I want to know where are these locations and what films are related to that very place. Wikipedias where they have articles are not important, that's why I want to use Wikidata. Bináris (talk) 08:02, 6 November 2024 (UTC)
- Great, thank you! Now I have to guess how to transform this to Pywikibot... Bináris (talk) 10:30, 5 November 2024 (UTC)
Annual energy output by countries?
[edit]Hi, Is there a query to obtain annual electricity production for countries? There is a property P4131 for annual energy output, but it is determined for power plants. Summing up all power plants gives a very approximate result.
Is it possible to get annual electricity generation by countries? Maybe by referencing external data sources? TVBig (talk) 17:42, 4 November 2024 (UTC)
- @User:TVBig
- Try it!
#defaultView:Table SELECT #?item ?itemLabel ?itemDescription ?countryLabel (sum(?output) as ?sum_output) { ?item wdt:P4131 ?output. ?item wdt:P17 ?country. SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE]". } } group by ?countryLabel
- This is my solution. But, the result is not correct. Because you have also plants out of service with a former energy output. This had to be excluded. And some countries have strange sums. If I look at all items with P4131:
- Try it!
#defaultView:Table SELECT ?item ?itemLabel ?itemDescription ?countryLabel ?output { ?item wdt:P4131 ?output. ?item wdt:P17 ?country. SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE]". } }
- You see different values. Also negative values. I think we have to normalize also the values KW, MW, GW. But I dont found a way to do this. For areas you see a solution here Wikidata:Request_a_query#prefecture_level_cities_sorted_by_area. --sk (talk) 20:37, 4 November 2024 (UTC)
@sk: To get the normalized quantity it's useful to use the full statement form and not the truthy one. For standards quantities, Wikidata has a database of normalization conversion factors it uses to output, see mw:Wikibase/Indexing/RDF_Dump_Format#Normalised_quantity This gives something like this :
#defaultView:Table
SELECT ?item ?itemLabel ?itemDescription
?countryLabel ?output ?unitLabel
{
?item p:P4131 [
psn:P4131 [
wikibase:quantityAmount ?output ; wikibase:quantityUnit ?unit
]
].
?item wdt:P17 ?country.
SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE]". }
}
author TomT0m / talk page 11:50, 5 November 2024 (UTC)
- Thanks @TomT0m. I will read it. Here is a new query for @TVBig. It is the Output in TeraJoule per Country.
- Try it!
:#defaultView:Table :SELECT ?countryLabel (sum(?output/1000/1000/1000/1000) as ?output_TJ) :{ : ?item p:P4131 [ : psn:P4131 [ : wikibase:quantityAmount ?output ; wikibase:quantityUnit ?unit : ] : ]. : ?item wdt:P17 ?country. : SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE]". } :} :group by ?countryLabel :order by desc(?output_TJ) :
- But I think we have an error in one data. France make 1000 times more then China. I search for the biggest output in France and found Centrale hydroélectrique de Romanche Gavet (Q30740209) with 503.659.561 GWh. Please check this data. --sk (talk) 23:42, 7 November 2024 (UTC)
Most recently edited lexemes for a language in WDQS
[edit]A question was raised at the Search Platform Team hour: Most recently edited lexemes for a language and URL to the API would be possible: https://www.wikidata.org/wiki/Special:ApiSandbox#action=query&format=json&list=search&formatversion=2&srsearch=linksto%3AQ9035&srnamespace=146&srlimit=500&srsort=last_edit_desc
I am wondering if this can be changed to a WDQS query? I have been trying versions of the following SPARQL query and have not found a version working:
SELECT ?item ?itemLabel WHERE {
{
SELECT ?item WHERE {
SERVICE wikibase:mwapi {
bd:serviceParam wikibase:endpoint "www.wikidata.org" ;
wikibase:api "Generator" ;
mwapi:generator "search" ;
mwapi:gsrsearch "linksto:Q9035" ;
# mwapi:gsrnamespace "146" ;
# mwapi:gsrsort "last_edit_desc" ;
mwapi:gsrlimit "100" .
?item wikibase:apiOutputItem mwapi:item .
}
} LIMIT 100
}
hint:Prior hint:runFirst "true".
SERVICE wikibase:label { bd:serviceParam wikibase:language "en". }
}
LIMIT 100
Finn Årup Nielsen (fnielsen) (talk) 17:38, 6 November 2024 (UTC)
- I manage to find the the output should be mwapi:title and not mwapi:item:
SELECT
?lexeme ?lemma
WHERE {
{
SELECT ?lexeme WHERE {
SERVICE wikibase:mwapi {
bd:serviceParam wikibase:endpoint "www.wikidata.org" ;
wikibase:api "Generator" ;
mwapi:generator "search" ;
mwapi:gsrsearch "linksto:Q9035" ;
mwapi:gsrnamespace "146" ;
mwapi:gsrsort "last_edit_desc" ;
mwapi:gsrlimit 100 .
?item_ wikibase:apiOutputItem mwapi:title .
}
BIND(IRI(CONCAT("http://www.wikidata.org/entity/", SUBSTR(STR(?item_), 39))) AS ?lexeme)
}
LIMIT 100
}
hint:Prior hint:runFirst "true".
?lexeme wikibase:lemma ?lemma .
}
- Thanks to having the modification date available to us, we can do this in pure SPARQL: https://w.wiki/Bsmj Infrastruktur (talk) 16:15, 7 November 2024 (UTC)
- Thanks! Interestingly the mwapi version may be faster than the non-mwapi version. Finn Årup Nielsen (fnielsen) (talk) 16:59, 7 November 2024 (UTC)
Missing LIS terms in Hungarian
[edit]Hi, I would need some help. I would like to retrieve library and information science (Q13420675) terms that are not translated into Hungarian, so we can translate the missing terms all at once. I expect no more than 1-200 terms. Example: document retrieval (Q1638872).
The properties I would need: QID, EN preferred label, EN description, EN alternative label(s), DE preferred label, DE alternative label(s). Thank you in advance! Bencemac (talk) 20:19, 12 November 2024 (UTC)
Help to move this query into a format so that I can make ListeriaBot process it
[edit]The only thing I need are 2 columns.
- 1 that says the game name in English or if English doesn't exist, any other language.
- 2nd column should say publication date.
If possible, could the query be designed so it sorts latest publication date and when it goes down the list it should be older?
I'm using ListeriaBot to do tests on this User:SuperUltraHardCoreGamer/Sandbox subpage of mine(Sandbox) where I try to figure out how ListeriaBot works.
If this works it should probably not be on my page and instead be moved to the Wikidata:WikiProject Video Games. I also have a query for Nintendo Switch games but what motivates me to edit is based on adding Steam Deck compatibility data which is why I don't include right now the other query.
# Steam Deck verified titles on Wikidata query.
#title:Steam Deck verified titles
SELECT ?item WHERE {
?item wdt:P8956 wd:Q107542665;
p:P8956 ?statement.
?statement pq:P1552 wd:Q117413402.
}
SuperUltraHardCoreGamer (talk) 09:51, 14 November 2024 (UTC)