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.
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.
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
osm_iterator-0.0.1.tar.gz
(1.8 kB
view hashes)
Built Distribution
Close
Hashes for osm_iterator-0.0.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 21ef6fb3759e4fbf8d43c640a2b5378662af24b0f7185c80308c0f99b004f498 |
|
MD5 | be00246172902500fddf1421c8ab569a |
|
BLAKE2b-256 | 854e763729ad6a725d405edebbb6006f2ccede5ab55b061a5a32396c74470572 |