Bug report #10427
.osm files have problems with iterator or number of features
|Affected QGIS version:||2.2.0||Regression?:||No|
|Operating System:||Easy fix?:||No|
|Pull Request or Patch supplied:||No||Resolution:||end of life|
|Crashes QGIS or corrupts data:||No||Copied to github as #:||18841|
QGIS is loading .osm files fine, but there seems something wrong with the number of features QGIS thinks there is in the layer.
If you open the osm-file which is in attached test.zip, and load those (small part of Amsterdam), you see a lot of points.
But asking the number of features (for example in the properties/Metadata dialog) shows '-1'.
Also python scripts which should work on for example a selected feature, fail because of null features.
See also: #10000 (processing)
Loading qml files created for this, crashes my QGIS (build master dd june 3 2014)
QGIS is using the ogr provider for this, and if I use ogrinfo, it shows the number of features ok:
ogrinfo lisdodde.osm -sql "SELECT COUNT FROM points"
COUNT_* (Integer) = 6523
#1 Updated by Jukka Rahkonen about 6 years ago
This relates / is the same as #10000
GDAL/ogrinfo does not report the feature count but it tells that it is unknown (-1). This is because it can be awfully slow to get the feature count from big osm files because all the data must be parsed first. For points it might be tolerable but resolving for example multipolygons is very heavy. You can try yourself
>ogrinfo germany.osm.pbf -sql "select count(*) from multipolygons"
Running this query is actually slower than converting the whole .pbf file into Spatialite with ogr2ogr. I canceled the query after 40 minutes. Probably some resource makes a bad bottleneck with large dataset. Getting an answer from finland-latest.osm.pbf took 2 and a half minutes which is also too long. Result was "COUNT_* (Integer) = 783693"
I guess that QGIS should be be made to load the data first and count the features once the job is done. Calculating feature count from big .osm or .pbf files just is not reasonable.
#4 Updated by Even Rouault almost 4 years ago
OSM/PBF files are extremely GIS unfriendly and, unless very small, require conversion to another format to be used in practice. That said with the new Dataset::GetNextFeature() API added in GDAL 2.2dev per https://trac.osgeo.org/gdal/wiki/rfc66_randomlayerreadwrite things should be better, although there is no direct QGIS API match.
Not sure what to do with this ticket
#6 Updated by Giovanni Manghi over 1 year ago
- Status changed from Open to Closed
- Resolution set to end of life
End of life notice: QGIS 2.18 LTR