Ierate over .osm file and call a provided callback function for each element
Project description
This code loads .osm file and allows to call function on all OSM objects in dataset.
It is distributed as an osm_iterator
PyPI package.
Usage example:
from osm_iterator.osm_iterator import Data
def show_places(element):
place_tag = element.get_tag_value("place")
name_tag = element.get_tag_value("name")
osm_object_url = element.get_link()
if place_tag != None:
print(name_tag + " is an object " + osm_object_url)
osm = Data("file.osm")
osm.iterate_over_data(show_places)
Design explanation: this code has deeply suboptimal handling of pretty much everything. For start, all data is loaded into memory and then duplicated in-memory dataset is created.
As result, attempt to process any large datasets will cause issues due to excessive memory consumption.
This situation is consequence of following facts
- This code was written during my first attempt to process OSM data using Python
- API allows (at least in theory) to painlessly switch to real iterator that is not loading all data into memory at once
- So far this was good enough for my purposes so I had no motivation to spend time on something working well
Though, if someone has good ideas (especially in form of a working code) - comments and pull requests are welcomed.
Publishing new version
Run from directory with setup.py
:
python3 setup.py sdist bdist_wheel
twine upload dist/*
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for osm_iterator-0.0.4-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 327f3f2bcb86e38e0a67921aa5b5d3f10bff2105f4349b07a8c0e3a4bf5734b0 |
|
MD5 | b6ad206100c012f79fb009e851c7f205 |
|
BLAKE2b-256 | 85ed384e3bf389b9d357539edc93924bfbb18712cf92c280b42b2e4d0a2f4f30 |