I'm trying to streamline the process whereby we build tiles (of ~30 layers, representing planning zone and zone-overlay boundaries). I have a strong preference for FOSS tools.
A couple of our people - and a couple of key clients - are only really comfortable in MapInfo, but I'm comfortable converting across platforms (using OGR) because I prefer PostGIS/QGIS/Python. However the source files are always (or nearly always) MapInfo TAB.
Many of the TAB files are 'thematic'; the theme style results either from the values taken by one aspatial field (e.g., 'LGA'), or from the interaction of 2 aspatial fields (e.g., 'Zone' and 'Status'). The thematically-different combinations ought to be different layers (or better yet, different files) but they ain't: I have no control over that, otherwise it would change and this question would be moot.
So I'm trying to separate out these layers, style them (that's easy) and then chop them into a maptile pyramid (super-easy). The eventual aim is to build XML files so that (python + mapnik) can style each layer, then chew it into a tile pyramid.
I'ma do it in Python with mapnik and ogr.
Now
ds = mapnik.Ogr(base=[dir], file =[tabfile], layer_by_index=0)` or just
ds = ogr.Open('[tabfile]')brings a TAB file into a Python script without any problem - analogous entries in the tag in an XML file would do likewise.
In the mapnik version, ds.fields() shows me the right headers, and I can add rule filters to extract specific subsets of the data to style as I wish, e.g.,
m=mapnik.Map(800,600)s=mapnik.Style()r=mapnik.Rule() r.filter = mapnik.Expression("([Zone]='IN2Z') and ([Status]='n')")s.rules.append(r)m.append_style('IND_01', s)What I would like to do, is to loop through distinct values of, say, Zone and Status, and filter a new dataset (and apply a new style) at each step.
If there was a way to return a vector of the unique values of the relevant field, I could simply iterate through the vector and do my dastardly work: for example, if I have a TAB file BH.TAB with column 'LGA', at the command-line I can do
ogrinfo -sql "select distinct LGA from BH" BH.TAB
This (piped to a file, say) can be parsed to fetch the vector of unique LGA in BH.TAB.
So now - finally - the question.
Does anyone know ogr's Python bindings well enough to know how to emulate the ogrinfo command-line syntax shown above? Once I can get that sucker into the mix I will find a way to parse it.
I swear I have RTFD (e.g., the Python/OGR Cookbook, which is pretty comprehensive), to no avail.
أكثر...
A couple of our people - and a couple of key clients - are only really comfortable in MapInfo, but I'm comfortable converting across platforms (using OGR) because I prefer PostGIS/QGIS/Python. However the source files are always (or nearly always) MapInfo TAB.
Many of the TAB files are 'thematic'; the theme style results either from the values taken by one aspatial field (e.g., 'LGA'), or from the interaction of 2 aspatial fields (e.g., 'Zone' and 'Status'). The thematically-different combinations ought to be different layers (or better yet, different files) but they ain't: I have no control over that, otherwise it would change and this question would be moot.
So I'm trying to separate out these layers, style them (that's easy) and then chop them into a maptile pyramid (super-easy). The eventual aim is to build XML files so that (python + mapnik) can style each layer, then chew it into a tile pyramid.
I'ma do it in Python with mapnik and ogr.
Now
ds = mapnik.Ogr(base=[dir], file =[tabfile], layer_by_index=0)` or just
ds = ogr.Open('[tabfile]')brings a TAB file into a Python script without any problem - analogous entries in the tag in an XML file would do likewise.
In the mapnik version, ds.fields() shows me the right headers, and I can add rule filters to extract specific subsets of the data to style as I wish, e.g.,
m=mapnik.Map(800,600)s=mapnik.Style()r=mapnik.Rule() r.filter = mapnik.Expression("([Zone]='IN2Z') and ([Status]='n')")s.rules.append(r)m.append_style('IND_01', s)What I would like to do, is to loop through distinct values of, say, Zone and Status, and filter a new dataset (and apply a new style) at each step.
If there was a way to return a vector of the unique values of the relevant field, I could simply iterate through the vector and do my dastardly work: for example, if I have a TAB file BH.TAB with column 'LGA', at the command-line I can do
ogrinfo -sql "select distinct LGA from BH" BH.TAB
This (piped to a file, say) can be parsed to fetch the vector of unique LGA in BH.TAB.
So now - finally - the question.
Does anyone know ogr's Python bindings well enough to know how to emulate the ogrinfo command-line syntax shown above? Once I can get that sucker into the mix I will find a way to parse it.
I swear I have RTFD (e.g., the Python/OGR Cookbook, which is pretty comprehensive), to no avail.
أكثر...