forked from osm-fr/osmose-backend
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathanalyser_merge_tourism_FR.py
128 lines (118 loc) · 5.86 KB
/
analyser_merge_tourism_FR.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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
#!/usr/bin/env python
#-*- coding: utf-8 -*-
###########################################################################
## ##
## Copyrights Noémie Lehuby 2020 ##
## ##
## This program is free software: you can redistribute it and/or modify ##
## it under the terms of the GNU General Public License as published by ##
## the Free Software Foundation, either version 3 of the License, or ##
## (at your option) any later version. ##
## ##
## This program is distributed in the hope that it will be useful, ##
## but WITHOUT ANY WARRANTY; without even the implied warranty of ##
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ##
## GNU General Public License for more details. ##
## ##
## You should have received a copy of the GNU General Public License ##
## along with this program. If not, see <http://www.gnu.org/licenses/>. ##
## ##
###########################################################################
import json
from modules.OsmoseTranslation import T_
from .Analyser_Merge_Dynamic import Analyser_Merge_Dynamic, SubAnalyser_Merge_Dynamic
from .Analyser_Merge import Source, CSV, Load, Mapping, Select, Generate
class Analyser_Merge_tourism_FR(Analyser_Merge_Dynamic):
def __init__(self, config, logger = None):
Analyser_Merge_Dynamic.__init__(self, config, logger)
mapingfile = json.loads(open("merge_data/tourism_FR.mapping.json").read())
for r in mapingfile:
self.classFactory(SubAnalyser_Datatourisme_FR, r['classes'], r['items'], r['classes'], r['title'], r['type'], r['tags_select'], r.get('osm_types', ['nodes', 'ways']), r['conflationDistance'], r['tags_generate'])
class SubAnalyser_Datatourisme_FR(SubAnalyser_Merge_Dynamic):
def __init__(self, config, error_file, logger, items, classs, title, type_, tags_select, osm_types, conflationDistance, tags_generate):
SubAnalyser_Merge_Dynamic.__init__(self, config, error_file, logger)
self.def_class_missing_official(item = items, id = classs, level = 3, tags = ['merge'],
title = T_('{0} not integrated', T_(title)))
self.init(
"https://data.datatourisme.gouv.fr",
"DATAtourisme, la base nationale des données du tourisme en Open Data",
CSV(Source(attribution = "data.gouv.fr:DATAtourisme", millesime = "05/2020", fileUrlCache = 7, # 7d to avoid auto-disable of the data source
fileUrl = "https://diffuseur.datatourisme.gouv.fr/webservice/84c2e2e54073df2b931c9f4bf8a3ccf3/b7f07a07-2b8f-4fcb-a74f-fdd68b0f57d5")),
Load("Longitude", "Latitude",
select = {'type': type_},
uniq = ["elem"]),
Mapping(
select = Select(
types = osm_types,
tags = tags_select),
conflationDistance = conflationDistance,
generate = Generate(
static1 = tags_generate,
static2 = {"source": self.source},
mapping1 = {
"ref:FR:CRTA": lambda fields: fields["identifier"] if fields["publisher_name"] == "SIRTAQUI Nouvelle-Aquitaine" else None,
"contact:phone": "contact_phone",
"contact:email": "contact_email",
"contact:website": "contact_website",
"wheelchair": lambda fields: {"true": "yes", "false": "no"}.get(fields["wheelchair"]),
"takeaway": lambda fields: {"true": "yes", "false": "no"}.get(fields["takeaway"]),
"official_name": "label"},
text = lambda tags, fields: {"en": "{} - {} - {} {} - {}".format(fields["label"], fields["street_address"], fields["postalcode_address"], fields["city_address"], fields["elem"])} )))
# the csv data is generated with the following request:
sparql = """
PREFIX dt: <https://www.datatourisme.gouv.fr/ontology/core#>
PREFIX schema: <http://schema.org/>
PREFIX purl: <http://purl.org/dc/elements/1.1/>
SELECT
?publisher_name ?identifier
?elem ?type ?label
?Latitude ?Longitude ?street_address ?postalcode_address ?city_address
?wheelchair ?takeaway ?contact_phone ?contact_email ?contact_website
WHERE {
?elem <http://www.w3.org/1999/02/22-rdf-syntax-ns#type> ?type;
<http://www.w3.org/2000/01/rdf-schema#label> ?label;
dt:isLocatedAt ?location.
FILTER (?type IN (
dt:Camping,
dt:Church,
dt:Restaurant,
dt:LocalTouristOffice,
dt:Museum,
dt:PointOfView,
dt:PicnicArea,
dt:WineCellar
)).
?location schema:geo ?geo.
?geo schema:latitude ?Latitude;
schema:longitude ?Longitude.
?location schema:address ?address.
?address schema:streetAddress ?street_address;
schema:postalCode ?postalcode_address;
schema:addressLocality ?city_address.
OPTIONAL {
?elem dt:hasBeenPublishedBy ?publisher.
?publisher schema:legalName ?publisher_name.
}
OPTIONAL {
?elem purl:identifier ?identifier.
}
OPTIONAL {
?elem dt:hasBookingContact ?agent_contact.
?agent_contact schema:telephone ?contact_phone.
}
OPTIONAL {
?elem dt:hasBookingContact ?agent_contact.
?agent_contact schema:email ?contact_email.
}
OPTIONAL {
?elem dt:hasBookingContact ?agent_contact.
?agent_contact <http://xmlns.com/foaf/0.1/homepage> ?contact_website.
}
OPTIONAL {
?elem dt:reducedMobilityAccess ?wheelchair.
}
OPTIONAL {
?elem dt:takeAway ?takeaway.
}
}
"""