[GRASS-SVN] r44767 - grass/trunk/lib/python

svn_grass at osgeo.org svn_grass at osgeo.org
Wed Dec 29 13:07:14 EST 2010


Author: martinl
Date: 2010-12-29 10:07:14 -0800 (Wed, 29 Dec 2010)
New Revision: 44767

Modified:
   grass/trunk/lib/python/vector.py
Log:
pythonlib: vector_what() implemented


Modified: grass/trunk/lib/python/vector.py
===================================================================
--- grass/trunk/lib/python/vector.py	2010-12-29 16:56:08 UTC (rev 44766)
+++ grass/trunk/lib/python/vector.py	2010-12-29 18:07:14 UTC (rev 44767)
@@ -13,7 +13,7 @@
 ...
 @endcode
 
-(C) 2008-2009 by the GRASS Development Team
+(C) 2008-2010 by the GRASS Development Team
 This program is free software under the GNU General Public
 License (>=v2). Read the file COPYING that comes with GRASS
 for details.
@@ -23,6 +23,7 @@
 """
 
 import os
+import types
 
 from core import *
 
@@ -216,3 +217,106 @@
     
     return { 'columns' : columns,
              'values' : values }
+
+# interface to v.what
+def vector_what(name, coord, distance = 0.0):
+    """!Query vector map at given locations
+    
+    To query one vector map at one location
+    @code
+    print grass.vector_what(name = 'archsites', coord = (595743, 4925281), distance = 250)
+
+    [{'Category': 8, 'Map': 'archsites', 'Layer': 1, 'Key_column': 'cat',
+      'Database': '/home/martin/grassdata/spearfish60/PERMANENT/dbf/',
+      'Mapset': 'PERMANENT', 'Driver': 'dbf',
+      'Attributes': {'str1': 'No_Name', 'cat': '8'},
+      'Table': 'archsites', 'Type': 'Point', 'Id': 8}]
+    @endcode
+
+    To query one vector map at more locations
+    @code
+    for q in grass.vector_what(name = ('archsites', 'roads'), coord = (595743, 4925281),
+                               distance = 250):
+        print q['Map'], q['Attributes']
+                            
+    archsites {'str1': 'No_Name', 'cat': '8'}
+    roads {'label': 'interstate', 'cat': '1'}
+    @endcode
+
+    To query more vector maps at one location
+    @code
+    for q in grass.vector_what(name = 'archsites', coord = [(595743, 4925281), (597950, 4918898)],
+                               distance = 250):
+        print q['Map'], q['Attributes']
+
+    archsites {'str1': 'No_Name', 'cat': '8'}
+    archsites {'str1': 'Bob_Miller', 'cat': '22'}
+    @endcode
+
+    @param name vector map(s) to query given as string or list/tuple
+    @param coord coordinates of query given as tuple (easting, northing) or list of tuples
+    @param distance query threshold distance (in map units)
+
+    @return parsed list
+    """
+    if os.environ.has_key("LC_ALL"):
+        locale = os.environ["LC_ALL"]
+        os.environ["LC_ALL"] = "C"
+    
+    if type(name) is types.StringType:
+        name_list = [name]
+    else:
+        name_list = name
+    
+    layer_list = ['-1'] * len(name_list)
+    
+    coord_list = list()
+    if type(coord) is types.TupleType:
+        coord_list.append('%f,%f' % (coord[0], coord[1]))
+    else:
+        for e, n in coord:
+            coord_list.append('%f,%f' % (e, n))
+    
+    ret = read_command('v.what',
+                       quiet      = True,
+                       flags      = 'ag',
+                       map        = ','.join(name_list),
+                       layer      = ','.join(layer_list),
+                       east_north = ','.join(coord_list),
+                       distance   = float(distance))
+    
+    if os.environ.has_key("LC_ALL"):
+        os.environ["LC_ALL"] = locale
+        
+    data = list()
+    if not ret:
+        return data
+    
+    dict_attrb = None
+    for item in ret.splitlines():
+        try:
+            key, value = map(lambda x: x.strip(), item.split('=', 1))
+        except ValueError:
+            continue
+        if key in ('East', 'North'):
+            continue
+        
+        if key == 'Map':
+            dict_main  = { 'Map' : value }
+            dict_attrb = None
+            data.append(dict_main)
+            continue
+        else:
+            if dict_attrb is not None:
+                dict_attrb[key] = value
+            else:
+                if key in ('Category', 'Layer', 'Id'):
+                    dict_main[key] = int(value)
+                else:
+                    dict_main[key] = value
+            if key == 'Key_column':
+                # skip attributes
+                dict_attrb = dict()
+                dict_main['Attributes'] = dict_attrb
+    
+    return data



More information about the grass-commit mailing list