This driver reads OpenStreetMap files, in .osm (XML based) and .pbf (optimized binary) formats.
The driver is available if GDAL is built with SQLite support and, for .osm XML files, with Expat support.
The filenames must end with .osm or .pbf extension.
The driver will categorize features into 5 layers :
The customization is essentially which OSM attributes and keys should be translated into OGR layer fields.
For example :
ogr2ogr -f PostgreSQL "PG:dbname=osm" test.pbf -lco COLUMN_TYPES=other_tags=hstore
For indexation of nodes, a custom mechanism not relying on SQLite is used by default (indexation of ways to solve relations is still relying on SQLite). It can speed up operations significantly. However, in some situations (non increasing node ids, or node ids not in expected range), it might not work and the driver will output an error message suggesting to relaunch by defining the OSM_USE_CUSTOM_INDEXING configuration option to NO.
When custom indexing is used (default case), the OSM_COMPRESS_NODES configuration option can be set to YES (the default is ON). This option might be turned on to improve performances when I/O access is the limiting factor (typically the case of rotational disk), and will be mostly efficient for country-sized OSM extracts where compression rate can go up to a factor of 3 or 4, and help keep the node DB to a size that fit in the OS I/O caches. For whole planet file, the effect of this option will be less efficient. This option consumes addionnal 60 MB of RAM.
    int bHasLayersNonEmpty;
    do
    {
        bHasLayersNonEmpty = FALSE;
        for( int iLayer = 0; iLayer < poDS->GetLayerCount(); iLayer++ )
        {
            OGRLayer *poLayer = poDS->GetLayer(iLayer);
            OGRFeature* poFeature;
            while( (poFeature = poLayer->GetNextFeature()) != NULL )
            {
                bHasLayersNonEmpty = TRUE;
                OGRFeature::DestroyFeature(poFeature);
            }
        }
    }
    while( bHasLayersNonEmpty );
Note : the ogr2ogr application has been modified to use that OGR_INTERLEAVED_READING mode without any particular user action.
bzcat my.osm.bz2 | ogr2ogr -f SQLite my.sqlite /vsistdin/You can convert a .osm or .pbf file without downloading it :
wget -O - http://www.example.com/some.pbf | ogr2ogr -f SQLite my.sqlite /vsistdin/ or ogr2ogr -f SQLite my.sqlite /vsicurl_streaming/http://www.example.com/some.pbf -progressAnd to combine the above steps :
wget -O - http://www.example.com/some.osm.bz2 | bzcat | ogr2ogr -f SQLite my.sqlite /vsistdin/