ESCatastroLib 0.0.1rc4__py2.py3-none-any.whl → 1.0.0__py2.py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
File without changes
File without changes
File without changes
@@ -17,7 +17,8 @@ def to_geodataframe(parcelas: list) -> gpd.GeoDataFrame:
17
17
  return gpd.GeoDataFrame({
18
18
  "rc": pc.rc,
19
19
  "tipo": pc.tipo,
20
- "superficie": pc.superficie,
20
+ "superficie_total": pc.superficie_total,
21
+ "superficie_construida": pc.superficie_construida,
21
22
  "provincia": pc.provincia,
22
23
  "municipio": pc.municipio,
23
24
  "regiones": ','.join([f"{reg.get('descripcion')} ({reg.get('superficie')} m^2)" for reg in pc.regiones]) ,
File without changes
@@ -1,8 +1,11 @@
1
1
  URL_BASE_CALLEJERO = 'https://ovc.catastro.meh.es/OVCServWeb/OVCWcfCallejero/COVCCallejero.svc/json'
2
2
  URL_BASE_COORDENADAS = 'https://ovc.catastro.meh.es/OVCServWeb/OVCWcfCallejero/COVCCoordenadas.svc/json'
3
3
  URL_BASE_GEOGRAFIA = 'http://ovc.catastro.meh.es/INSPIRE/wfsCP.aspx'
4
+ URL_BASE_WFS_EDIFICIOS = "https://ovc.catastro.meh.es/INSPIRE/wfsBU.aspx"
4
5
  URL_BASE_CROQUIS_DATOS = f'https://www1.sedecatastro.gob.es/CYCBienInmueble/SECImprimirCroquisYDatos.aspx'
5
6
  URL_BASE_CARTOCIUDAD_GEOCODER = 'https://www.cartociudad.es/geocoder/api/geocoder'
7
+ URL_BASE_MAPA_VALORES_URBANOS = "https://www1.sedecatastro.gob.es/Cartografia/SECDameGeoJSON.aspx"
8
+ URL_BASE_MAPA_VALORES_RUSTICOS = "https://www1.sedecatastro.gob.es/Cartografia/GeoServerWMS.aspx"
6
9
 
7
10
  MAPEOS_PROVINCIAS = {
8
11
  'La Coruña': 'A Coruña',
@@ -138,4 +141,32 @@ SISTEMAS_REFERENCIA = {
138
141
  'EPSG:23029': 'UTM huso 29N en ED50',
139
142
  'EPSG:23030': 'UTM huso 30N en ED50',
140
143
  'EPSG:23031': 'UTM huso 31N en ED50'
141
- }
144
+ }
145
+
146
+ CULTIVOS = {
147
+ "ARZ": "Arrozal",
148
+ "CBP": "Cultivos bajo plástico",
149
+ "CIT": "Cítricos",
150
+ "FCR": "Frutal carnoso regadío",
151
+ "FCS": "Frutal carnoso secano",
152
+ "FSR": "Frutos secos regadío",
153
+ "FSS": "Frutos secos secano",
154
+ "HUE": "Huerta",
155
+ "OLR": "Olivar regadío",
156
+ "OLS": "Olivar secano",
157
+ "PLT": "Plátanos",
158
+ "SBT": "Cultivos tropicales y subtropicales",
159
+ "TAR": "Tierras arables regadío",
160
+ "TAS": "Tierras arables secano",
161
+ "VIP": "Viñedo parral",
162
+ "VIR": "Viñedo regadío",
163
+ "VIS": "Viñedo secano",
164
+ "VOL": "Viña olivar",
165
+ "PAR": "Pasto con arbolado",
166
+ "PRD": "Prados",
167
+ "PST": "Pastizal",
168
+ "CON": "Coníferas",
169
+ "FRL": "Frondosas de crecimiento lento",
170
+ "FRR": "Frondosas de crecimiento rápido",
171
+ "MTR": "Matorral"
172
+ }
@@ -1,7 +1,9 @@
1
1
  import requests
2
2
  import json
3
3
 
4
- from typing import Union
4
+ from geopy.distance import geodesic
5
+
6
+ from typing import Union, List
5
7
 
6
8
  from .statics import URL_BASE_CALLEJERO, MAPEOS_PROVINCIAS, TIPOS_VIA, SISTEMAS_REFERENCIA, URL_BASE_COORDENADAS, URL_BASE_CARTOCIUDAD_GEOCODER
7
9
  from .exceptions import lanzar_excepcion
@@ -222,3 +224,13 @@ def geocodificar_direccion(direccion: str, municipio: str = None):
222
224
  def lon_lat_from_coords_dict(coords):
223
225
  return float(coords["x"]), float(coords["y"])
224
226
 
227
+ def lat_lon_from_coords_dict(coords):
228
+ return float(coords['y']), float(coords['x'])
229
+
230
+ def distancia_entre_dos_puntos_geograficos(origen: List[float], destino: List[float]):
231
+ """
232
+ Devuelve la distancia en metros entre dos puntos geográficos usando latitud y longitud.
233
+ ¡OJO! Las tuplas deben ser latitud y longitud y no al revés.
234
+ """
235
+ return geodesic(origen,destino).m
236
+
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: ESCatastroLib
3
- Version: 0.0.1rc4
3
+ Version: 1.0.0
4
4
  Summary: Una librería de Python para consultar los datos del Catastro COMO OBJETOS. Incluye información geográfica.
5
5
  Project-URL: Documentation, https://github.com/IvanitiX/ESCatastroLib#readme
6
6
  Project-URL: Issues, https://github.com/IvanitiX/ESCatastroLib/issues
@@ -10,7 +10,6 @@ License: Apache License (2.0)
10
10
  License-File: LICENSE
11
11
  Keywords: catastro,espana,gis,spain
12
12
  Classifier: Development Status :: 3 - Alpha
13
- Classifier: Framework :: Pytest
14
13
  Classifier: Intended Audience :: Developers
15
14
  Classifier: License :: OSI Approved :: Apache Software License
16
15
  Classifier: Natural Language :: Spanish
@@ -18,11 +17,14 @@ Classifier: Operating System :: OS Independent
18
17
  Classifier: Programming Language :: Python :: 3
19
18
  Classifier: Topic :: Software Development :: Build Tools
20
19
  Requires-Dist: folium
21
- Requires-Dist: geopandas
22
- Requires-Dist: pyarrow
23
- Requires-Dist: pytest
20
+ Requires-Dist: geopandas<0.14; python_version < '3.9'
21
+ Requires-Dist: geopandas>=0.14; python_version >= '3.9'
22
+ Requires-Dist: geopy
23
+ Requires-Dist: pyarrow<14; python_version < '3.9'
24
+ Requires-Dist: pyarrow>=14; python_version >= '3.9'
24
25
  Requires-Dist: requests
25
- Requires-Dist: shapely
26
+ Requires-Dist: shapely<2; python_version < '3.9'
27
+ Requires-Dist: shapely>=2; python_version >= '3.9'
26
28
  Requires-Dist: xmltodict
27
29
  Description-Content-Type: text/markdown
28
30
 
@@ -116,6 +118,34 @@ referencia a una MetaParcela.
116
118
  * `regiones (list)`: Una lista de regiones en la parcela con una descripción y superficie.
117
119
  * `centroide (dict)`: Las coordenadas del centroide de la parcela. (Latitud y longitud)
118
120
  * `geometria (list)`: Una lista de puntos que representan la geometría de la parcela. (Latitud y longitud)
121
+ * `superficie_total (float)`: La superficie total de la parcela en metros cuadrados.
122
+ * `superficie_construida (float)`: La superficie construida en metros cuadrados.
123
+ * `superficie (float)`: La superficie total de las regiones en metros cuadrados.
124
+
125
+ **Métodos:**
126
+
127
+ * `distancias_aristas` (property): Calcula las distancias entre puntos consecutivos de la geometría de la parcela.
128
+ * Returns: `Optional[List[float]]` - Lista de distancias entre aristas consecutivas en metros, o None si no hay geometría.
129
+
130
+ * `perimetro` (property): Calcula el perímetro total de la geometría de la parcela.
131
+ * Returns: `Optional[float]` - Perímetro total en metros, o None si no hay geometría.
132
+
133
+ * `valor_catastral_urbano_m2(anio: int) -> Optional[float]`: Obtiene el valor catastral por metro cuadrado para parcelas urbanas.
134
+ * Args: `anio` (int) - Año del valor catastral a consultar.
135
+ * Returns: Valor catastral en €/m², 0 si es rústica, o None si hay algún error.
136
+
137
+ * `valor_catastral_rustico_m2(anio: str) -> Optional[Dict]`: Obtiene los valores catastrales de tierras para parcelas rústicas.
138
+ * Args: `anio` (str) - Año del valor catastral a consultar.
139
+ * Returns: Diccionario con `region`, `nombre_region` y `modulos_€/ha`, o None si no se encuentran.
140
+
141
+ * `numero_plantas` (property): Obtiene el número de plantas de un edificio.
142
+ * Returns: `Dict[str, Any]` con claves `plantas`, `sotanos` y `total`.
143
+
144
+ * `to_dataframe()`: Convierte la parcela en un GeoDataFrame de GeoPandas.
145
+ * `to_json(filename: Optional[str] = None) -> str`: Convierte la parcela a JSON.
146
+ * `to_csv(filename: Optional[str] = None) -> str`: Convierte la parcela a CSV.
147
+ * `to_shapefile(filename: str)`: Guarda la parcela como Shapefile.
148
+ * `to_parquet(filename: str)`: Guarda la parcela como Parquet.
119
149
 
120
150
 
121
151
  ## Clase MetaParcela
@@ -0,0 +1,15 @@
1
+ ESCatastroLib/__about__.py,sha256=buISjIv39OyjZ4jasw7ncClX_p6X5LIUq6vQCYP8qqc,128
2
+ ESCatastroLib/__init__.py,sha256=QCXZ5qTCAGhkZr63i0Y7zZpkLKd342edUzjt9U_Ujqs,220
3
+ ESCatastroLib/models/Calle.py,sha256=TfgJfRiCSl6Fgug2--Wo2x5cj6JQdhHQojtZDZOgVSo,2846
4
+ ESCatastroLib/models/InfoCatastral.py,sha256=szmAdCmFS_J2-IgBv5UuowAGwAPF5xhuKoRddNYv8xA,34485
5
+ ESCatastroLib/models/Municipio.py,sha256=J3X9G7EMc63651EDAMOqo846Ed-5cVjJfZLZeohPw74,1566
6
+ ESCatastroLib/models/__init__.py,sha256=Y8nN1Qp3_-VX7njuXwFWSq-62clHj878miEQGnzNXlc,149
7
+ ESCatastroLib/utils/__init__.py,sha256=kQj0ORkR_JMgwWgGi73APqn3p-UQipiuMY1QaBBmkLs,106
8
+ ESCatastroLib/utils/converters.py,sha256=JFRuFvIidRxVJitCPukHAcFsraIuqR-hfSaU0vleGfU,2705
9
+ ESCatastroLib/utils/exceptions.py,sha256=YM3AuKHZ61SYgpmtYFz9n7JavdEOq2mLwyk2VzIol5A,759
10
+ ESCatastroLib/utils/statics.py,sha256=YZ202WkreqsPKwhVxuNDVBWagobYWUIJdbh6vBw_b2s,5169
11
+ ESCatastroLib/utils/utils.py,sha256=mecrCnjlJX8dA1edmsRhEP_3MfIR68GFxtfTUfIHGEE,9218
12
+ escatastrolib-1.0.0.dist-info/METADATA,sha256=0ye6_LUFEsuTXaazqyeFRyv3LUxCPbLX8aKnA-MciuA,20050
13
+ escatastrolib-1.0.0.dist-info/WHEEL,sha256=aha0VrrYvgDJ3Xxl3db_g_MDIW-ZexDdrc_m-Hk8YY4,105
14
+ escatastrolib-1.0.0.dist-info/licenses/LICENSE,sha256=kgDY5GRu9WGoKk_0F0iYmXuLmGiZ9hgtReHhCfJBWr8,11319
15
+ escatastrolib-1.0.0.dist-info/RECORD,,
@@ -1,5 +1,5 @@
1
1
  Wheel-Version: 1.0
2
- Generator: hatchling 1.27.0
2
+ Generator: hatchling 1.28.0
3
3
  Root-Is-Purelib: true
4
4
  Tag: py2-none-any
5
5
  Tag: py3-none-any
@@ -1,427 +0,0 @@
1
- import requests
2
- import json
3
- import xmltodict
4
-
5
- from typing import Union
6
-
7
- from ..utils.statics import URL_BASE_CALLEJERO, URL_BASE_GEOGRAFIA, URL_BASE_CROQUIS_DATOS
8
- from ..utils.utils import comprobar_errores, listar_sistemas_referencia, lon_lat_from_coords_dict
9
- from ..utils.exceptions import ErrorServidorCatastro
10
- from ..utils import converters
11
- from .Calle import Calle, Municipio
12
-
13
- class ParcelaCatastral:
14
- """
15
- Clase que representa una parcela catastral.
16
- Args:
17
- rc (str, optional): La referencia catastral de la parcela. Defaults to None. Puede ir solo.
18
-
19
- provincia (int|str, optional): El código o nombre de la provincia. Defaults to None. Se usa para buscar por dirección o parcela.
20
- municipio (int|str, optional): El código o nombre del municipio. Defaults to None. Se usa para buscar por dirección o parcela.
21
- poligono (int, optional): El número del polígono. Defaults to None. Se usa para buscar por parcela.
22
- parcela (int, optional): El número de la parcela. Defaults to None. Se usa para buscar por parcela.
23
- tipo_via (str, optional): El tipo de vía de la dirección. Defaults to None. Se usa para buscar por dirección.
24
- calle (str, optional): El nombre de la calle de la dirección. Defaults to None. Se usa para buscar por dirección.
25
- numero (str, optional): El número de la dirección. Defaults to None. Se usa para buscar por dirección.
26
- Raises:
27
- ValueError: Se lanza si no se proporciona suficiente información para realizar la búsqueda o si la RC corresponde a una MetaParcela.
28
- ErrorServidorCatastro: Se lanza si hay un error en el servidor del Catastro.
29
- Attributes:
30
- rc (str): La referencia catastral de la parcela.
31
- provincia (int|str): El código o nombre de la provincia.
32
- municipio (int|str): El código o nombre del municipio.
33
- poligono (int): El número del polígono. Sólo se da en terrenos Rústicos.
34
- parcela (int): El número de la parcela. Sólo se da en terrenos Rústicos.
35
- tipo_via (str): El tipo de vía de la dirección. Sólo se da en terrenos Urbanos.
36
- calle (str): El nombre de la calle de la dirección. Sólo se da en terrenos Urbanos.
37
- numero (str): El número de la dirección. Sólo se da en terrenos Urbanos.
38
- url_croquis (str): La URL del croquis de la parcela.
39
- tipo (str): El tipo de la parcela (Urbano o Rústico).
40
- antiguedad (str): La antigüedad de la parcela (solo para parcelas urbanas).
41
- uso (str): El uso de la parcela (solo para parcelas urbanas).
42
- nombre_paraje (str): El nombre del paraje (solo para parcelas rústicas).
43
- regiones (list): Una lista de regiones de la parcela, cada una con una descripción y superficie.
44
- centroide (dict): Las coordenadas del centroide de la parcela.
45
- geometria (list): Una lista de puntos que representan la geometría de la parcela.
46
- """
47
-
48
- def __create_regions(self, info_cadastre: dict):
49
- self.regiones = []
50
- if self.tipo == 'Urbano':
51
- iterator = list(info_cadastre.values())[0].get('bico').get('lcons')
52
- elif self.tipo == 'Rústico':
53
- iterator = list(info_cadastre.values())[0].get('bico').get('lspr')
54
- for region in iterator:
55
- if self.tipo == 'Rústico':
56
- self.regiones.append({
57
- 'descripcion': region.get('dspr').get('dcc'),
58
- 'superficie': region.get('dspr').get('ssp')
59
- })
60
- elif self.tipo == 'Urbano':
61
- self.regiones.append({
62
- 'descripcion': region.get('lcd'),
63
- 'superficie': region.get('dfcons').get('stl')
64
- })
65
-
66
-
67
- def __create_geometry(self, projection: str = 'EPSG:4326'):
68
- geometry_request = requests.get(f'{URL_BASE_GEOGRAFIA}',
69
- params={
70
- 'service':'wfs',
71
- 'version':'2',
72
- 'request':'getfeature',
73
- 'STOREDQUERIE_ID':'GetParcel',
74
- 'refcat': self.rc,
75
- 'srsname': projection
76
- })
77
-
78
- geometry = xmltodict.parse(geometry_request.content)
79
- geoposition = geometry.get('FeatureCollection').get('member').get('cp:CadastralParcel').get('cp:referencePoint').get('gml:Point').get('gml:pos').split(' ')
80
- self.centroide = {
81
- 'x': geoposition[1],
82
- 'y': geoposition[0]
83
- }
84
- parcel_geometry = geometry.get('FeatureCollection').get('member').get('cp:CadastralParcel').get('cp:geometry').get('gml:MultiSurface').get('gml:surfaceMember').get('gml:Surface').get('gml:patches').get('gml:PolygonPatch').get('gml:exterior').get('gml:LinearRing').get('gml:posList').get('#text').split(' ')
85
- self.geometria = [
86
- {
87
- 'x': parcel_geometry[2*idx+1],
88
- 'y': parcel_geometry[2*idx]
89
- } for idx in range(len(parcel_geometry)//2)
90
- ]
91
-
92
- def __create_from_rc(self, rc: str, projection: str):
93
- """Create an instance of InfoCatastral from a RC (Referencia Catastral) string."""
94
- req1 = requests.get(f'{URL_BASE_CALLEJERO}/Consulta_DNPRC',
95
- params={'RefCat': rc})
96
-
97
- if len(req1.content) > 0:
98
- info_cadastre = json.loads(req1.content)
99
- if comprobar_errores(info_cadastre):
100
- cudnp = info_cadastre.get("consulta_dnprcResult", {}).get("control", {}).get("cudnp", 1)
101
-
102
- if cudnp > 1:
103
- raise ErrorServidorCatastro(mensaje="Esta parcela tiene varias referencias catastrales. Usa un objeto MetaParcela.")
104
- else:
105
- self.rc = ''.join(info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('idbi').get('rc').values())
106
- self.url_croquis = requests.get(URL_BASE_CROQUIS_DATOS, params={'refcat': self.rc}).url
107
- self.municipio = info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('dt').get('nm')
108
- self.provincia = info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('dt').get('np')
109
- self.tipo = 'Rústico' if info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('idbi').get('cn') == 'RU' else 'Urbano'
110
- if self.tipo == 'Urbano':
111
- self.calle = f"{info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('dt').get('locs').get('lous').get('lourb').get('dir').get('tv')} {info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('dt').get('locs').get('lous').get('lourb').get('dir').get('nv')}"
112
- self.numero = info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('dt').get('locs').get('lous').get('lourb').get('dir').get('pnp')
113
- self.antiguedad = info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('debi').get('ant')
114
- self.uso = info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('debi').get('luso')
115
- elif self.tipo == 'Rústico':
116
- self.parcela = info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('dt').get('locs').get('lors').get('lorus').get('cpp').get('cpa')
117
- self.poligono = info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('dt').get('locs').get('lors').get('lorus').get('cpp').get('cpo')
118
- self.nombre_paraje = info_cadastre.get('consulta_dnprcResult').get('bico').get('bi').get('dt').get('locs').get('lors').get('lorus').get('npa')
119
-
120
- self.__create_regions(info_cadastre)
121
- self.__create_geometry(projection)
122
-
123
- self.superficie = sum(float(region.get('superficie')) for region in self.regiones)
124
- else:
125
- raise ErrorServidorCatastro("El servidor ha devuelto una respuesta vacia")
126
-
127
- def __create_from_parcel(self, provincia: Union[str,None], municipio: Union[str,None], poligono: Union[str,None], parcela: Union[str,None], projection: str):
128
- """Create an instance of InfoCatastral from a parcela string."""
129
- req = requests.get(f'{URL_BASE_CALLEJERO}/Consulta_DNPPP',
130
- params={
131
- 'Provincia': provincia,
132
- 'Municipio': municipio,
133
- 'Poligono': poligono,
134
- 'Parcela': parcela
135
- })
136
- if len(req.content) > 0:
137
- info_cadastre = json.loads(req.content)
138
- if comprobar_errores(info_cadastre):
139
- cudnp = info_cadastre.get("consulta_dnpppResult", {}).get("control", {}).get("cudnp", 1)
140
-
141
- if cudnp > 1:
142
- raise ErrorServidorCatastro(mensaje="Esta parcela tiene varias referencias catastrales. Usa un objeto MetaParcela.")
143
- else:
144
- self.rc = ''.join(info_cadastre.get('consulta_dnpppResult').get('bico').get('bi').get('idbi').get('rc').values())
145
- self.__create_from_rc(self.rc, projection)
146
- else:
147
- raise ErrorServidorCatastro("El servidor ha devuelto una respuesta vacia")
148
-
149
- def __create_from_address(self, provincia: Union[str,None], municipio: Union[str,None], tipo_via: Union[str,None], calle: Union[str,None], numero: Union[str,None], projection: str):
150
- """Create an instance of InfoCatastral from an address string."""
151
- info_calle = Calle(
152
- municipio=Municipio(
153
- provincia=provincia,
154
- municipio=municipio
155
- ),
156
- tipo_via=tipo_via,
157
- nombre_calle=calle
158
- )
159
-
160
- if info_calle:
161
- req = requests.get(f'{URL_BASE_CALLEJERO}/Consulta_DNPLOC',
162
- params={
163
- 'Provincia': info_calle.municipio.provincia,
164
- 'Municipio': info_calle.municipio.municipio,
165
- 'Sigla': info_calle.tipo_via,
166
- 'Calle': info_calle.calle,
167
- 'Numero': numero
168
- })
169
-
170
- if req.status_code == 200 and len(req.content) > 0 and comprobar_errores(req.json()):
171
- info_cadastre = json.loads(req.content)
172
- cudnp = info_cadastre.get("consulta_dnplocResult", {}).get("control", {}).get("cudnp", 1)
173
-
174
- if cudnp > 1:
175
- raise ErrorServidorCatastro(mensaje="Esta parcela tiene varias referencias catastrales. Usa un objeto MetaParcela.")
176
- else:
177
- if 'lrcdnp' in info_cadastre.get('consulta_dnplocResult'):
178
- self.rc = ''.join(info_cadastre.get('consulta_dnplocResult').get('lrcdnp').get('rcdnp')[0].get('rc').values())
179
- elif 'bico' in info_cadastre.get('consulta_dnplocResult'):
180
- self.rc = ''.join(info_cadastre.get('consulta_dnplocResult').get('bico').get('bi').get('idbi').get('rc').values())
181
- self.__create_from_rc(self.rc, projection)
182
- elif 'lerr' in json.loads(req.content).get('consulta_dnplocResult') and json.loads(req.content)['consulta_dnplocResult']['lerr'][0]['cod'] == '43':
183
- info_cadastre = json.loads(req.content)
184
- raise Exception(f"Ese número no existe. Prueba con alguno de estos: {[num.get('num').get('pnp') for num in info_cadastre.get('consulta_dnplocResult').get('numerero').get('nump')]}")
185
- else:
186
- raise ErrorServidorCatastro("El servidor ha devuelto una respuesta vacia")
187
-
188
-
189
- else:
190
- raise Exception('La calle no existe.')
191
-
192
- def __init__(self, rc: Union[str,None] = None, provincia: Union[str,None] = None, municipio: Union[int,str,None] = None, poligono: Union[int,None] = None, parcela: Union[int,None] = None, tipo_via: Union[str,None] = None, calle: Union[str,None] = None, numero: Union[str,None] = None, projection: str = 'EPSG:4326'):
193
- if projection not in listar_sistemas_referencia():
194
- raise ValueError(f"El sistema de referencia {projection} no existe. Los sistemas de referencia disponibles son: {listar_sistemas_referencia()}")
195
- if rc:
196
- self.rc = rc
197
- self.__create_from_rc(rc, projection)
198
- elif provincia and municipio and poligono and parcela:
199
- self.provincia = provincia
200
- self.municipio = municipio
201
- self.poligono = poligono
202
- self.parcela = parcela
203
- self.__create_from_parcel(provincia, municipio, poligono, parcela, projection)
204
- elif provincia and municipio and tipo_via and calle and numero:
205
- self.provincia = provincia
206
- self.municipio = municipio
207
- self.calle = calle
208
- self.numero = numero
209
- self.__create_from_address(provincia, municipio, tipo_via, calle, numero, projection)
210
- else:
211
- raise ValueError("No se ha proporcionado suficiente información para realizar la búsqueda")
212
-
213
-
214
- def to_dataframe(self):
215
- """
216
- Convierte la parcela en un DataFrame de pandas.
217
-
218
- Returns:
219
- pd.DataFrame: Un DataFrame que contiene los datos de la parcela.
220
- """
221
- return converters.to_geodataframe([self])
222
-
223
- def to_json(self, filename: Union[str,None] = None) -> str:
224
- """
225
- Convierte la parcela en un JSON.
226
-
227
- Args:
228
- filename (Union[str,None], optional): Nombre del archivo donde guardar el JSON. Defaults to None.
229
-
230
- Returns:
231
- str: Una cadena JSON que contiene los datos de la parcela.
232
- """
233
- return converters.to_json([self], filename)
234
-
235
- def to_csv(self, filename: Union[str,None] = None) -> str:
236
- """
237
- Convierte la parcela en un CSV.
238
-
239
- Args:
240
- filename (Union[str,None], optional): Nombre del archivo donde guardar el CSV. Defaults to None.
241
-
242
- Returns:
243
- str: Una cadena CSV que contiene los datos de la parcela.
244
- """
245
- return converters.to_csv([self], filename)
246
-
247
- def to_shapefile(self, filename: str):
248
- """
249
- Guarda la parcela como un archivo Shapefile.
250
-
251
- Args:
252
- filename (str): El nombre del archivo Shapefile a guardar.
253
- """
254
- converters.to_shapefile([self], filename)
255
-
256
- def to_parquet(self, filename: str):
257
- """
258
- Guarda la parcela como un archivo Parquet.
259
-
260
- Args:
261
- filename (str): El nombre del archivo Parquet a guardar.
262
- """
263
- converters.to_parquet([self], filename)
264
-
265
- class MetaParcela:
266
- """
267
- Clase que representa una MetaParcela, es decir, una gran parcela catastral con
268
- varias referencias catastrales (Parcelas Catastrales más pequeñas).
269
-
270
- Args:
271
- rc (Union[str,None]): La referencia catastral de la MetaParcela.
272
-
273
- provincia (int|Union[str,None]): El nombre de la provincia donde se encuentra la MetaParcela.
274
- municipio (int|Union[str,None]): El nombre del municipio donde se encuentra la MetaParcela.
275
- poligono (Union[int,None]): El número de polígono de la MetaParcela. Sólo se usa para buscar por parcela.
276
- parcela (Union[int,None]): El número de parcela de la MetaParcela. Sólo se usa para buscar por parcela.
277
- tipo_via (Union[str,None]): El tipo de vía de la dirección de la MetaParcela. Sólo se usa para buscar por dirección.
278
- calle (Union[str,None]): El nombre de la calle de la dirección de la MetaParcela. Sólo se usa para buscar por dirección.
279
- numero (Union[str,None]): El número de la dirección de la MetaParcela. Sólo se usa para buscar por dirección.
280
- Attributes:
281
- rc (str): La referencia catastral de la MetaParcela.
282
- parcelas (list): Una lista de ParcelaCatastral que representan las parcelas que componen la MetaParcela.
283
-
284
- """
285
-
286
- def __create_from_rc(self, rc: str):
287
- """Create an instance of InfoCatastral from a RC (Referencia Catastral) string."""
288
- req1 = requests.get(f'{URL_BASE_CALLEJERO}/Consulta_DNPRC',
289
- params={'RefCat': rc})
290
-
291
- if len(req1.content) > 0:
292
- info_cadastre = json.loads(req1.content)
293
- if comprobar_errores(info_cadastre):
294
- self.parcelas = []
295
- num_parcelas = info_cadastre.get("consulta_dnprcResult", {}).get("control", {}).get("cudnp", 1)
296
- for idx in range(num_parcelas):
297
- rc = ''.join(info_cadastre.get('consulta_dnprcResult').get('lrcdnp').get('rcdnp')[idx].get('rc').values())
298
- self.parcelas.append(ParcelaCatastral(rc=rc))
299
- else:
300
- raise ErrorServidorCatastro("El servidor ha devuelto una respuesta vacia")
301
-
302
-
303
- def __create_from_parcel(self, provincia: Union[str,None], municipio: Union[str,None], poligono: Union[str,None], parcela: Union[str,None]):
304
- """Create an instance of InfoCatastral from a parcela string."""
305
- req = requests.get(f'{URL_BASE_CALLEJERO}/Consulta_DNPPP',
306
- params={
307
- 'Provincia': provincia,
308
- 'Municipio': municipio,
309
- 'Poligono': poligono,
310
- 'Parcela': parcela
311
- })
312
- if len(req.content) > 0:
313
- info_cadastre = json.loads(req.content)
314
- if comprobar_errores(info_cadastre):
315
- self.parcelas = []
316
- num_parcelas = info_cadastre.get("consulta_dnpppResult", {}).get("control", {}).get("cudnp", 1)
317
- for idx in range(num_parcelas):
318
- rc = ''.join(info_cadastre.get('consulta_dnpppResult').get('lrcdnp').get('rcdnp')[idx].get('rc').values())
319
- self.parcelas.append(ParcelaCatastral(rc=rc))
320
- else:
321
- raise ErrorServidorCatastro("El servidor ha devuelto una respuesta vacia")
322
-
323
- def __create_from_address(self, provincia: Union[str,None], municipio: Union[str,None], tipo_via: Union[str,None], calle: Union[str,None], numero: Union[str,None]):
324
- """Create an instance of InfoCatastral from an address string."""
325
- info_calle = Calle(
326
- municipio=Municipio(
327
- provincia=provincia,
328
- municipio=municipio
329
- ),
330
- tipo_via=tipo_via,
331
- nombre_calle=calle
332
- )
333
-
334
- if info_calle:
335
- req = requests.get(f'{URL_BASE_CALLEJERO}/Consulta_DNPLOC',
336
- params={
337
- 'Provincia': info_calle.municipio.provincia,
338
- 'Municipio': info_calle.municipio.municipio,
339
- 'Sigla': info_calle.tipo_via,
340
- 'Calle': info_calle.calle,
341
- 'Numero': numero
342
- })
343
-
344
- if req.status_code == 200 and len(req.content) > 0 and comprobar_errores(req.json()):
345
- info_cadastre = json.loads(req.content)
346
- self.parcelas = []
347
- num_parcelas = info_cadastre.get("consulta_dnplocResult", {}).get("control", {}).get("cudnp", 1)
348
- for idx in range(num_parcelas):
349
- rc = ''.join(info_cadastre.get('consulta_dnplocResult').get('lrcdnp').get('rcdnp')[idx].get('rc').values())
350
- self.parcelas.append(ParcelaCatastral(rc=rc))
351
- else:
352
- raise ErrorServidorCatastro("El servidor ha devuelto una respuesta vacia")
353
-
354
- else:
355
- raise Exception('La calle no existe.')
356
-
357
- def __init__(self, rc: Union[str,None] = None, provincia: Union[int,str,None] = None, municipio: Union[int,str,None] = None, poligono: Union[int,None] = None, parcela: Union[int,None] = None, tipo_via: Union[str,None] = None, calle: Union[str,None] = None, numero: Union[str,None] = None):
358
- if rc:
359
- self.rc = rc
360
- self.__create_from_rc(rc)
361
- elif provincia and municipio and poligono and parcela:
362
- self.provincia = provincia
363
- self.municipio = municipio
364
- self.poligono = poligono
365
- self.parcela = parcela
366
- self.__create_from_parcel(provincia, municipio, poligono, parcela)
367
- elif provincia and municipio and tipo_via and calle and numero:
368
- self.provincia = provincia
369
- self.municipio = municipio
370
- self.calle = calle
371
- self.numero = numero
372
- self.__create_from_address(provincia, municipio, tipo_via, calle, numero)
373
- else:
374
- raise ValueError("No se ha proporcionado suficiente información para realizar la búsqueda")
375
-
376
-
377
- def to_dataframe(self):
378
- """
379
- Convierte la MetaParcela en un DataFrame de pandas.
380
-
381
- Returns:
382
- pd.DataFrame: Un DataFrame que contiene las parcelas de la MetaParcela.
383
- """
384
- return converters.to_geodataframe(self.parcelas)
385
-
386
- def to_json(self, filename: Union[str,None] = None) -> str:
387
- """
388
- Convierte la MetaParcela en un JSON.
389
-
390
- Args:
391
- filename (Union[str,None], optional): Nombre del archivo donde guardar el JSON. Defaults to None.
392
-
393
- Returns:
394
- str: Una cadena JSON que contiene las parcelas de la MetaParcela.
395
- """
396
- return converters.to_json(self.parcelas, filename)
397
-
398
- def to_csv(self, filename: Union[str,None] = None) -> str:
399
- """
400
- Convierte la MetaParcela en un CSV.
401
-
402
- Args:
403
- filename (Union[str,None], optional): Nombre del archivo donde guardar el CSV. Defaults to None.
404
-
405
- Returns:
406
- str: Una cadena CSV que contiene las parcelas de la MetaParcela.
407
- """
408
- return converters.to_csv(self.parcelas, filename)
409
-
410
- def to_shapefile(self, filename: str):
411
- """
412
- Guarda la MetaParcela como un archivo Shapefile.
413
-
414
- Args:
415
- filename (str): El nombre del archivo Shapefile a guardar.
416
- """
417
- converters.to_shapefile(self.parcelas, filename)
418
-
419
- def to_parquet(self, filename: str):
420
- """
421
- Guarda la MetaParcela como un archivo Parquet.
422
-
423
- Args:
424
- filename (str): El nombre del archivo Parquet a guardar.
425
- """
426
- converters.to_parquet(self.parcelas, filename)
427
-
@@ -1,15 +0,0 @@
1
- escatastrolib/__about__.py,sha256=AewrDcLR1tQuIZMxuJxO3bT_jYsC-D1tpsXR9A0cF94,131
2
- escatastrolib/__init__.py,sha256=QCXZ5qTCAGhkZr63i0Y7zZpkLKd342edUzjt9U_Ujqs,220
3
- escatastrolib/models/Calle.py,sha256=TfgJfRiCSl6Fgug2--Wo2x5cj6JQdhHQojtZDZOgVSo,2846
4
- escatastrolib/models/InfoCatastral.py,sha256=H8Eo96OThC_OSnpQ7Jeuwo4We5f1XZ4C51lbvcDUSq4,23308
5
- escatastrolib/models/Municipio.py,sha256=J3X9G7EMc63651EDAMOqo846Ed-5cVjJfZLZeohPw74,1566
6
- escatastrolib/models/__init__.py,sha256=Y8nN1Qp3_-VX7njuXwFWSq-62clHj878miEQGnzNXlc,149
7
- escatastrolib/utils/__init__.py,sha256=kQj0ORkR_JMgwWgGi73APqn3p-UQipiuMY1QaBBmkLs,106
8
- escatastrolib/utils/converters.py,sha256=cxjesg23z0gxhaquuPaEQjhgb2Gnj5Ip2BqX_n3wY0s,2621
9
- escatastrolib/utils/exceptions.py,sha256=YM3AuKHZ61SYgpmtYFz9n7JavdEOq2mLwyk2VzIol5A,759
10
- escatastrolib/utils/statics.py,sha256=PpHPS-lopMYWg5pJeeCU5NtIJU6nUpeh9njFFKwfVfc,3958
11
- escatastrolib/utils/utils.py,sha256=76ZuW_kFjAjazLztvGnsiuKrvzyPx_e0flhTqp2yaDU,8772
12
- escatastrolib-0.0.1rc4.dist-info/METADATA,sha256=08CGcJ_dUg-XoBhuMczsRaNd6YjbMSheRzUqvcywZlU,18067
13
- escatastrolib-0.0.1rc4.dist-info/WHEEL,sha256=tkmg4JIqwd9H8mL30xA7crRmoStyCtGp0VWshokd1Jc,105
14
- escatastrolib-0.0.1rc4.dist-info/licenses/LICENSE,sha256=kgDY5GRu9WGoKk_0F0iYmXuLmGiZ9hgtReHhCfJBWr8,11319
15
- escatastrolib-0.0.1rc4.dist-info/RECORD,,