Nueva base de actualizada a Julio 2023 en https://www.pangodream.es/base-de-datos-codigos-postales-espana-julio-2023
En determinadas ocasiones necesitamos utilizar información geográfica en nuestras aplicaciones. No me refiero tanto a coordenadas geográficas sino simplemente a disponer de una relación de provincias, municipios, distritos, calles y códigos postales.
Desafortunadamente en España parece que los datos de dominio público se encuentran en un estado de disponibilidad muy precario y que cualquier oportunidad es buena para arañar unos cuantos euros a quien esté dispuesto a pagar por ellos.
Ayer tuve la necesidad de incluir información de este tipo en una de mis aplicaciones y cuál fue mi sorpresa cuando al ir a buscarla a internet para adaptarla me encontré con que aparentemente era información ‘de pago’.
En una búsqueda de Google como esta ‘base de datos codigos postales españa‘ aparece como primer resultado un enlace a la página de la empresa Correos en la que nos da instrucciones de cómo acceder a la base de datos de códigos postales previo pago de 687€ (en su versión más básica).
Indagando algo más encontré alguna referencia a reclamaciones realizadas en la página datos.gob.es cuya resolución dice textualmente:
La base de delimitaciones de códigos postales actualmente está sujeta a comercialización. Para adquirir el listado hay que seguir las instrucciones indicadas en la página de CORREOS
Personalmente me parece vergonzoso que este tipo de información esté comercializada por una empresa privada que nació con presupuesto público, pero España es así.
Dejando polémicas a un lado, seguí buscando y encontré una alternativa muy válida en la página del INE. El Callejero del Censo Electoral sirve perfectamente para este propósito ya que contiene información de todos los municipios de España con sus tramos de vías y pseudovías identificados con su correspondiente código postal. En la página de referencia existe un documento con la especificación de formato de cada uno de los ficheros que contienen la información:
- Tramos de vía
- Unidades poblacionales
- Vías
- Pseudovías
He realizado una importación y tratamiento de los ficheros para MySQL dejando únicamente la información esencial para poder montar un callejero con información de códigos postales.
La base de datos está disponible aquí. Una vez descomprimida ocupa 164MB.
Tras ejecutar el script SQL, encontraremos una base de datos llamada codpos que contendrá las siguientes tablas:
- provincia
- unidad_poblacional
- via
- pseudovia
- tramo
Tramo es la tabla que relaciona el resto y corresponde a los tramos de vía correspondientes a cada una de las secciones y subsecciones censales (información que he omitido de la base de datos).
Un ejemplo de utilización sería la siguiente SQL:
select t.cpro as `codigo_provincia`, pr.dpro as `provincia`, up.dmun as `municipio`, up.nentsic, up.nnucle, ifnull(pv.dpsvia, concat(v.tvia, ' ', v.nvia)) as `via`, t.cpos as `codigo_postal` from tramo t left outer join via v on(t.cpro = v.cpro and t.cmum = v.cmum and t.cvia = v.cvia) left outer join pseudovia pv on(t.cpro = pv.cpro and t.cmum = pv.cmum and t.cpsvia = pv.cpsvia) left outer join unidad_poblacional up on(t.cpro = up.cpro and t.cmum = up.cmum and t.cun = up.cun) left outer join provincia pr on(t.cpro = pr.cpro) where v.nvia like 'velazquez%' and 58 between t.ein and t.esn and pr.cpro = 28 and t.tinum = 2
que nos devolverá todos aquellos tramos de vía con denominación que empiece por ‘velazquez’, que contengan un número 58 entre sus pares (tinum = 2) y que estén en la provincia de Madrid (28).
Muchas gracias por el aporte. Me ha sido muy útil. Efectivamente, es una verguenza que la cartografía de CP no sea pública y, peor aún, que se comercialice.
Un saludo!
Gracias a ti Eduard por el comentario. 🙂
Como puedo abrirlo
Es un fichero comprimido .rar que contiene los scripts SQL de creación y carga de la BDD.
Un saludo
Muchas gracias Alberto, me ha venido como anillo al dedo.
Muchas gracias a ti por comentar Albert.
Un saludo,
Lo puto amo
He hecho mias las palabras de Alberto y las he convertido en twit para ayudar a la causa!
https://twitter.com/marc_torres_/status/1344667203673743363?s=19
Por si quereis hacer retwit! 🙂
Moltes gràcies, Marc.
Bon any nou!!!
Buenas Alberto un gran aporte, no se si seria posible o es muy complejo tener en tu sql tb el INE del municipio de cada código postal, para poder hacer búsquedas por código postal y sacar a que Municipio pertenece.
Hola David,
la verdad es que yo no tengo tiempo ni para echarle un ojo, pero igual alguien lo ha hecho ya o se anima a hacerlo.
Gracias por comentar.
Buenas tardes David, yo estoy usando la base de datos y el INE está en la tabla vía en el campo cvia sino estoy equivocado aunque lo he estado comparando y en principio es el mismo, saludos.
This is gret. Thanks for your work. Absurd that this info isn’t available for free (or a reasonable price at least).
Thanks Moritz!!!
Todo un detalle
Buenas, una pena el enlace no funciona
Existe una nueva base de datos con la información actualizada en Callejero español Julio 2023
La estructura no es la misma que en 2020 aunque básicamente es lo mismo. La base de datos actual contiene toda la información del INE.