| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 | #!/usr/bin/env python# SPDX-License-Identifier: AGPL-3.0-or-later# lint: pylint# pylint: disable=missing-module-docstring"""Fetch units from :origin:`searx/engines/wikidata.py` engine.Output file: :origin:`searx/data/wikidata_units.json` (:origin:`CI Update data...  <.github/workflows/data-update.yml>`)."""import jsonimport collections# set pathfrom os.path import joinfrom searx import searx_dirfrom searx.engines import wikidata, set_loggersset_loggers(wikidata, 'wikidata')# the response contains duplicate ?item with the different ?symbol# "ORDER BY ?item DESC(?rank) ?symbol" provides a deterministic result# even if a ?item has different ?symbol of the same rank.# A deterministic result# see:# * https://www.wikidata.org/wiki/Help:Ranking# * https://www.mediawiki.org/wiki/Wikibase/Indexing/RDF_Dump_Format ("Statement representation" section)# * https://w.wiki/32BT#   see the result for https://www.wikidata.org/wiki/Q11582#   there are multiple symbols the same rankSARQL_REQUEST = """SELECT DISTINCT ?item ?symbolWHERE{  ?item wdt:P31/wdt:P279 wd:Q47574 .  ?item p:P5061 ?symbolP .  ?symbolP ps:P5061 ?symbol ;           wikibase:rank ?rank .  FILTER(LANG(?symbol) = "en").}ORDER BY ?item DESC(?rank) ?symbol"""def get_data():    results = collections.OrderedDict()    response = wikidata.send_wikidata_query(SARQL_REQUEST)    for unit in response['results']['bindings']:        name = unit['item']['value'].replace('http://www.wikidata.org/entity/', '')        unit = unit['symbol']['value']        if name not in results:            # ignore duplicate: always use the first one            results[name] = unit    return resultsdef get_wikidata_units_filename():    return join(join(searx_dir, "data"), "wikidata_units.json")if __name__ == '__main__':    with open(get_wikidata_units_filename(), 'w', encoding="utf8") as f:        json.dump(get_data(), f, indent=4, ensure_ascii=False)
 |