-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate.py
108 lines (90 loc) · 3.25 KB
/
update.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
import requests
import csv
import urllib.parse
import configparser
def read_csv(dump='dump.csv'):
"""
read_csv(dump):
Obtiene el elemento del cache según la especificación de CSV
"""
try:
dumpstring = []
with open(dump, mode='rt', encoding='utf-8') as archivo:
for row in csv.reader(archivo, delimiter='|'):
dumpstring.append(row[0])
return sorted(dumpstring)
except FileNotFoundError:
return []
def write_csv(line, archivo='dump.csv', separador='|'):
"""
write_csv(archivo='dump.csv',delimeter=';',line):
Imprime en archivo la linea, separada por separador como csv
Jara (Asunción)|Avenida brasilia asuncion paraguay.jpg|<URL>
"""
with open(archivo, mode='a', encoding='utf-8') as csv_file:
writer = csv.writer(csv_file, delimiter=separador)
writer.writerow(line)
return None
def get_data():
"""
get_data():
Obtiene los datos desde la API
"""
payload = {'action': 'query', 'format': 'json', 'generator': 'categorymembers',
'prop': 'imageinfo', 'iiprop': 'user|timestamp',
'gcmtitle': 'Category:Images from Wiki Loves Earth 2018 in Chile', 'gcmtype': 'file',
'gcmlimit': 'max', 'gcmsort': 'timestamp'}
continuar = True
lista = []
while continuar == True:
data = requests.get(
'https://commons.wikipedia.org/w/api.php', payload)
datas = data.json()
lista += datas.get('query').get('pages').values()
if datas.get('continue'):
payload['gcmcontinue'] = datas.get('continue').get('gcmcontinue')
else:
continuar = False
print ("Artículos... {0}".format(len(lista)))
return lista
def convert_element(element):
"""
convert_element(element):
Normaliza un elemento para inyectarlo en la hoja de cálculo
"""
url = urllib.parse.quote(element.get('title'))
element['url'] = 'https://commons.wikimedia.org/wiki/{0}'.format(url)
element['titulo'] = element.get('title').replace('File:', '')
element['autor'] = element.get('imageinfo')[0].get('user', '?')
element['timestamp'] = element.get('imageinfo')[0].get('timestamp', '?')
return element
def add_docs(element):
"""
add_docs(element):
Añade un elemento a una hoja de cálculo en Google Docs, según la URL
"""
payload = {'Nombre': element.get('title'), 'URL': element.get('url'),
'Fecha': element.get('timestamp'), 'Autor': element.get('autor'),
'Identificable': '',
'Calidad': '', 'Derechos': '', 'Veredicto': '',
'Revisor': '', 'Comentarios': ''}
data = requests.get(url, payload)
def run_elements(lista):
"""
run_elements(lista):
Ejecuta la lista de valores
"""
elements = read_csv()
for el in lista:
el = convert_element(el)
if el.get('title') not in elements:
print ('Añadiendo {0}'.format(el.get('title')))
add_docs(el)
write_csv([el.get('title')])
def main():
run_elements(get_data())
if __name__ == '__main__':
config = configparser.ConfigParser()
config.read('config.ini')
url = config['default']['url']
main()