OSMPbfLoader
Bases: OSMLoader
OSMPbfLoader.
OSM(OpenStreetMap)[1] PBF(Protocolbuffer Binary Format)[2] loader is a loader capable of loading OSM features from a PBF file. It filters features based on OSM tags[3] in form of key:value pairs, that are used by OSM users to give meaning to geometries.
This loader uses pyosmium
[3] library capable of parsing an *.osm.pbf
file.
Additionally, it can download a pbf file extract for a given area using Protomaps API.
References
Source code in srai/loaders/osm_loaders/osm_pbf_loader.py
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 129 130 131 132 133 134 135 136 137 138 |
|
__init__
__init__(pbf_file: Optional[Union[str, Path]] = None, download_directory: Union[str, Path] = 'files') -> None
Initialize OSMPbfLoader.
PARAMETER | DESCRIPTION |
---|---|
pbf_file |
Downloaded
TYPE:
|
download_directory |
Directory where to save the downloaded
TYPE:
|
Source code in srai/loaders/osm_loaders/osm_pbf_loader.py
load
Load OSM features with specified tags for a given area from an *.osm.pbf
file.
The loader will use provided *.osm.pbf
file, or download extracts
using PbfFileDownloader
. Later it will parse and filter features from files
using PbfFileHandler
. It will return a GeoDataFrame containing the geometry
column
and columns for tag keys.
Some key/value pairs might be missing from the resulting GeoDataFrame,
simply because there are no such objects in the given area.
If you want to extract data for a big area (like country, or more), it's encouraged
to use existing *.osm.pbf
extracts from GeoFabrik (https://download.geofabrik.de/)
or BBBike (https://extract.bbbike.org/). You can provide those predownloaded files in
the constructor of the OSMPbfLoader
.
PARAMETER | DESCRIPTION |
---|---|
area |
Area for which to download objects.
TYPE:
|
tags |
A dictionary
specifying which tags to download.
The keys should be OSM tags (e.g.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
gpd.GeoDataFrame
|
gpd.GeoDataFrame: Downloaded features as a GeoDataFrame. |