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 different sources.
References
Source code in srai/loaders/osm_loaders/osm_pbf_loader.py
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 139 140 141 142 143 144 145 146 147 148 149 |
|
__init__
__init__(pbf_file: Optional[Union[str, Path]] = None, download_source: PbfSourceLiteral = 'protomaps', download_directory: Union[str, Path] = 'files', switch_to_geofabrik_on_error: bool = True) -> None
Initialize OSMPbfLoader.
PARAMETER | DESCRIPTION |
---|---|
pbf_file |
Downloaded
TYPE:
|
download_source |
Source to use when downloading PBF files.
Can be one of:
TYPE:
|
download_directory |
Directory where to save the downloaded
TYPE:
|
switch_to_geofabrik_on_error |
Flag whether to automatically
switch
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.
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:
|
RAISES | DESCRIPTION |
---|---|
ValueError
|
If PBF file is expected to be downloaded and provided geometries aren't shapely.geometry.Polygons. |
RETURNS | DESCRIPTION |
---|---|
gpd.GeoDataFrame
|
gpd.GeoDataFrame: Downloaded features as a GeoDataFrame. |