Я новичок в SPARQL, и мне удалось реализовать запрос, который возвращает исторический период времени (P2348), когда элемент был создан, примерами этого являются «Бронзовый век», «Мезолит», «Династия Нгуен» и т. д. Я также есть другие элементы, которые возвращают определенный год, когда они были созданы. Мне было интересно, есть ли способ преобразовать исторические периоды в приблизительный год вместо названия периода. Очевидно, что это не обязательно должно быть точным, всего лишь год в этот период времени.
как только вы получите годы, создайте строку замены с помощью BIND
и некоторых строковых функций
вот скетч (много чего сделать и/или оптимизировать): SELECT ?item ?itemLabel ?period ?periodLabel ?periodString { VALUES ?period {wd:Q44155} OPTIONAL {?period wdt:P580 ?start} OPTIONAL {?period wdt:P582 ?end} ?item wdt:P2348 ?period . BIND(CONCAT("from ", str(year(?start)), " to ", str(year(?end))) AS ?periodString) SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en". } } limit 10
Если у вас есть возраст, вы можете запросить время его начала и окончания. Вот пример:
select ?age ?age_name ?start_time ?end_time {
?age wdt:P31 wd:Q15401699. # age is archeological age.
?age rdfs:label ?age_name. filter(lang(?age_name)='en').
?age wdt:P580 ?start_time.
?age wdt:P582 ?end_time.
}
не уверен, что я понимаю, у вас есть неизвестный запрос (почему не показать его здесь, никто не хочет начинать с нуля), ок - и иногда период времени что-то вроде "Мезолита", который вы хотите заменить на какой-то конкретный год( с) вместо этого? Так откуда же взять эти данные? Либо предоставьте некоторые сопоставления от периода к году вручную, либо попробуйте запросить Викиданные за несколько лет об этих объектах исторического периода. См. wikidata.org/wiki/Q44155 — там указано время начала и окончания — очевидно, это может быть не для всех, может просто не существовать или используется какое-то другое свойство