-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathcorrect_label_capitalisation.py
110 lines (104 loc) · 4.99 KB
/
correct_label_capitalisation.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#!/usr/bin/python
# -*- coding: utf-8 -*-
# Make corrections to labels
# Mike Peel 24-Oct-2020 v1 - start
import pywikibot
from pywikibot import pagegenerators
wikidata_site = pywikibot.Site("wikidata", "wikidata")
repo = wikidata_site.data_repository()
replacements = [
{'lang': 'cs', 'string': 'Silnice I/', 'replacement': 'silnice I/'},\
{'lang': 'cs', 'string': 'Silnice II/', 'replacement': 'silnice II/'},\
{'lang': 'cs', 'string': 'Silnice III/', 'replacement': 'silnice III/'},\
{'lang': 'en', 'string': 'Route I/', 'replacement': 'route I/'},\
{'lang': 'en', 'string': 'Route II/', 'replacement': 'route II/'},\
{'lang': 'sk', 'string': 'Cesta I. triedy ', 'replacement': 'cesta I. triedy '},\
{'lang': 'sk', 'string': 'Cesta II. triedy ', 'replacement': 'cesta II. triedy '},\
{'lang': 'de', 'string': 'Cesta I. triedy ', 'replacement': 'cesta I. triedy '},\
{'lang': 'de', 'string': 'Cesta II. triedy ', 'replacement': 'cesta II. triedy '},\
{'lang': 'lmo', 'string': 'Strada de prima class ', 'replacement': 'strada de prima class '},\
{'lang': 'lmo', 'string': 'Strada de segonda class ', 'replacement': 'strada de segonda class '},\
{'lang': 'pl', 'string': 'Droga krajowa nr', 'replacement': 'droga krajowa nr'},\
{'lang': 'pl', 'string': 'Droga ekspresowa', 'replacement': 'droga ekspresowa'},\
{'lang': 'cs', 'string': 'Dálnice D', 'replacement': 'dálnice D'},\
{'lang': 'sk', 'string': 'Diaľnica D', 'replacement': 'diaľnica D'},\
{'lang': 'cs', 'string': 'Rychlostní silnice R', 'replacement': 'rychlostní silnice R'},\
{'lang': 'sk', 'string': 'Rýchlostná cesta R', 'replacement': 'rýchlostná cesta R'},\
{'lang': 'de', 'string': 'Rýchlostná cesta R', 'replacement': 'rýchlostná cesta R'},\
{'lang': 'cs', 'string': 'Železniční trať ', 'replacement': 'železniční trať '},\
{'lang': 'sk', 'string': 'Železničná trať ', 'replacement': 'železničná trať '},\
{'lang': 'pl', 'string': 'Linia kolejowa ', 'replacement': 'linia kolejowa '},\
{'lang': 'en', 'string': 'Railway line ', 'replacement': 'railway line '},\
{'lang': 'cs', 'string': 'Evropská silnice ', 'replacement': 'evropská silnice '},\
{'lang': 'cs', 'string': 'Mezinárodní silnice ', 'replacement': 'mezinárodní silnice '},\
{'lang': 'sk', 'string': 'Európska cesta ', 'replacement': 'európska cesta '},\
{'lang': 'es', 'string': 'Ruta europea ', 'replacement': 'ruta europea '},\
{'lang': 'fr', 'string': 'Route europeenne ', 'replacement': 'route europeenne '},\
{'lang': 'lmo', 'string': 'Strada europea ', 'replacement': 'strada europea '},\
{'lang': 'pl', 'string': 'Trasa europejska ', 'replacement': 'trasa europejska '},\
{'lang': 'pt', 'string': 'Estrada europeia ', 'replacement': 'estrada europeia '},\
{'lang': 'pt-br', 'string': 'Estrada europeia ', 'replacement': 'estrada europeia '},\
{'lang': 'ro', 'string': 'Drumul european ', 'replacement': 'drumul european '},\
{'lang': 'uk', 'string': "Автошлях ", 'replacement': 'aвтошлях'},\
{'lang': 'cs', 'string': "Trať ", 'replacement': "trať "},\
{'lang': 'pl', 'string': "Linia kolejowa ", 'replacement': "linia kolejowa "},\
]
debug = False
for replacement in replacements:
savemessage = 'Change ' + replacement['lang'] + ' label to '
query = 'SELECT ?item ?label'\
'WHERE'\
'{'\
' SERVICE wikibase:mwapi'\
' {'\
' bd:serviceParam wikibase:endpoint "www.wikidata.org" .'\
' bd:serviceParam wikibase:api "Generator" .'\
' bd:serviceParam mwapi:generator "search" .'\
' bd:serviceParam mwapi:gsrsearch \'inlabel:"'+replacement['string']+'@'+replacement['lang']+'"\' .'\
' bd:serviceParam mwapi:gsrlimit "max".'\
' ?item wikibase:apiOutputItem mwapi:title.'\
' }'\
' ?item rdfs:label ?label'\
' FILTER (LANG(?label) = "'+replacement['lang']+'")'\
' FILTER STRSTARTS(?label, "'+replacement['string']+'")'\
'}'
print(query)
count = 1
while count > 0:
pages = pagegenerators.WikidataSPARQLPageGenerator(query, site=repo)
count = 0
print('Running...')
for wd_item in pages:
count += 1
print(wd_item)
# wd_item = pywikibot.ItemPage.fromPage(page)
item_dict = wd_item.get()
qid = wd_item.title()
oldlabel = item_dict['labels'][replacement['lang']]
newlabel = oldlabel.replace(replacement['string'],replacement['replacement'],1)
newlabels = {replacement['lang']: newlabel}
test = 'y'
if debug:
test = input('Save?')
if test == 'y':
try:
wd_item.editLabels(labels=newlabels, summary=savemessage + newlabel)
except:
print("Something went wrong")
try:
aliases = item_dict['aliases'][replacement['lang']]
oldaliases = aliases.copy()
for i in range(0,len(aliases)):
aliases[i] = aliases[i].replace(replacement['string'],replacement['replacement'],1)
if oldaliases != aliases:
newaliases = {replacement['lang']: aliases}
test = 'y'
if debug:
test = input('Save?')
if test == 'y':
try:
wd_item.editAliases(aliases=newaliases, summary=savemessage + 'lower case')
except:
print("Something went wrong")
except:
continue