GRASS GIS logo

Note: A new GRASS GIS stable version has been released: GRASS GIS 7.4. Go directly to the new manual page here

pygrass.vector package

Submodules

pygrass.vector.abstract module

Created on Fri Aug 17 17:24:03 2012

@author: pietro

class pygrass.vector.abstract.Info(name, mapset='', *aopen, **kwopen)[source]

Bases: object

Basic vector info. To get access to the vector info the map must be opened.

>>> cens = Info('census')
>>> cens.open(mode='r')

Then it is possible to read and write the following map attributes:

>>> cens.organization
'NC OneMap'
>>> cens.person
'hmitaso'
>>> cens.title
'Wake County census blocks with attributes, clipped (polygon map)'
>>> cens.map_date
datetime.datetime(2007, 3, 19, 22, 1, 37)
>>> cens.date
''
>>> cens.scale
1
>>> cens.comment
''
>>> cens.comment = "One useful comment!"
>>> cens.comment
'One useful comment!'
>>> cens.zone
0
>>> cens.proj
99

There are some read only attributes:

>>> cens.full_name
'census@PERMANENT'
>>> cens.proj_name
'Lambert Conformal Conic'
>>> cens.maptype
'native'

And some basic methods:

>>> cens.is_3D()
False
>>> cens.exist()
True
>>> cens.is_open()
True
>>> cens.close()
build()[source]

Close the vector map and build vector Topology

close(build=False)[source]

Method to close the Vector

Parameters:build (bool) – True if the vector map should be build before close it
comment

Set or obtain the Vector comment

date

Set or obtain the Vector date

exist()[source]

Return if the Vector exists or not

full_name[source]

Return the full name of Vector

is_3D()[source]

Return if the Vector is 3D

is_open()[source]

Return if the Vector is open

map_date

Set or obtain the Vector map date

mapset

Set or obtain the Vector mapset

maptype[source]

Return the map type of Vector

name

Set or obtain the Vector name

open(mode=None, layer=1, overwrite=None, with_z=None, tab_name='', tab_cols=None, link_name=None, link_key='cat', link_db='$GISDBASE/$LOCATION_NAME/$MAPSET/sqlite/sqlite.db', link_driver='sqlite')[source]

Open a Vector map.

Parameters:
  • mode (str) – open a vector map in r in reading, w in writing and in rw read and write mode
  • layer (int) – specify the layer that you want to use
  • overwrite (bool) – valid only for w mode
  • with_z (bool) – specify if vector map must be open with third dimension enabled or not. Valid only for w mode, default: False
  • tab_name (str) – define the name of the table that will be generate
  • tab_cols (list of pairs) – define the name and type of the columns of the attribute table of the vecto map
  • link_name (str) – define the name of the link connecttion with the database
  • link_key (str) – define the nema of the column that will be use as vector category
  • link_db (str) – define the database connection parameters
  • link_driver – define witch database driver will be used
  • link_driver – str

Some of the parameters are valid only with mode w or rw

See more examples in the documentation of the read and write methods

organization

Set or obtain the Vector organization

person

Set or obtain the Vector author

proj

Set or obtain the Vector projection code

proj_name[source]

Return the project name of Vector

remove()[source]

Remove vector map

rename(newname)[source]

Method to rename the Vector map

Parameters:newname (str) – the new name for the Vector map
scale

Set or obtain the Vector scale

thresh

Set or obtain the Vector threshold

title

Set or obtain the Vector title

write_header()[source]

Save the change in the C struct permanently to disk.

zone

Set or obtain the Vector projection zone

pygrass.vector.abstract.is_open(c_mapinfo)[source]

Return if the Vector is open

pygrass.vector.basic module

Created on Tue Jul 31 13:06:20 2012

@author: pietro

class pygrass.vector.basic.Bbox(north=0, south=0, east=0, west=0, top=0, bottom=0)[source]

Bases: object

Instantiate a Bounding Box class that contains a ctypes pointer to the C struct bound_box, that could be used by C GRASS functions.

>>> bbox = Bbox()
>>> bbox
Bbox(0.0, 0.0, 0.0, 0.0)

The default parameters are 0. It is possible to set or change the parameters later, with:

>>> bbox.north = 10
>>> bbox.south = -10
>>> bbox.east = -20
>>> bbox.west = 20
>>> bbox
Bbox(10.0, -10.0, -20.0, 20.0)

Or directly istantiate the class with the values, with:

>>> bbox = Bbox(north=100, south=0, east=0, west=100)
>>> bbox
Bbox(100.0, 0.0, 0.0, 100.0)
bottom

Set and obtain bottom value

contains(point)[source]

Return True if the object is contained by the BoundingBox

Parameters:point (a Point object or a tuple with the coordinates) – the point to analyze
>>> from grass.pygrass.vector.geometry import Point
>>> poi = Point(5,5)
>>> bbox = Bbox(north=10, south=0, west=0, east=10)
>>> bbox.contains(poi)
True
east

Set and obtain east value

items()[source]
keys()[source]
north

Set and obtain north value

nsewtb(tb=True)[source]

Return a list of values from bounding box

Parameters:tb (bool) – if tb parameter is False return only: north, south, east, west and not top and bottom
south

Set and obtain south value

top

Set and obtain top value

west

Set and obtain west value

class pygrass.vector.basic.BoxList(boxlist=None)[source]

Bases: object

Instantiate a BoxList class to create a list of Bounding Box

append(box)[source]

Append a Bbox object to a Boxlist object, using the Vect_boxlist_append C fuction.

Parameters:
  • bbox – the bounding box to add to the list
  • bbox – a Bbox object
>>> box0 = Bbox()
>>> box1 = Bbox(1,2,3,4)
>>> box2 = Bbox(5,6,7,8)
>>> boxlist = BoxList([box0, box1])
>>> boxlist
Boxlist([Bbox(0.0, 0.0, 0.0, 0.0), Bbox(1.0, 2.0, 3.0, 4.0)])
>>> len(boxlist)
2
>>> boxlist.append(box2)
>>> len(boxlist)
3
have_boxes()[source]
ids[source]
n_values[source]
remove(indx)[source]

Remove Bbox from the boxlist, given an integer or a list of integer or a boxlist, using Vect_boxlist_delete C function or the Vect_boxlist_delete_boxlist.

Parameters:
  • indx – the index value of the Bbox to remove
  • indx – int
>>> boxlist = BoxList([Bbox(),
...                    Bbox(1, 0, 0, 1),
...                    Bbox(1, -1, -1, 1)])
>>> boxlist.remove(0)
>>> boxlist
Boxlist([Bbox(1.0, 0.0, 0.0, 1.0), Bbox(1.0, -1.0, -1.0, 1.0)])
reset()[source]

Reset the c_boxlist C struct, using the Vect_reset_boxlist C function.

>>> boxlist = BoxList([Bbox(),
...                    Bbox(1, 0, 0, 1),
...                    Bbox(1, -1, -1, 1)])
>>> len(boxlist)
3
>>> boxlist.reset()
>>> len(boxlist)
0
class pygrass.vector.basic.Cats(c_cats=None)[source]

Bases: object

Instantiate a Category class that contains a ctypes pointer to the C line_cats struct.

>>> cats = Cats()
>>> for cat in xrange(100, 110): cats.set(cat, layer=cat-50)
>>> cats.n_cats
10
>>> cats.cat
[100, 101, 102, 103, 104, 105, 106, 107, 108, 109]
>>> cats.layer
[50, 51, 52, 53, 54, 55, 56, 57, 58, 59]
>>> cats.get()  # default layer is 1
(-1, 0)
>>> cats.get(50)
(100, 1)
>>> cats.get(51)
(101, 1)
>>> cats.set(1001, 52)
>>> cats.cat
[100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 1001]
>>> cats.layer
[50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 52]
>>> cats.get(52)
(102, 2)
>>> cats.reset()
>>> cats.layer
[]
>>> cats.cat
[]
cat[source]
check_cats_constraints(cats_list, layer=1)[source]

Check if categories match with category constraints

Parameters:
  • cats_list (list) – a list of categories
  • layer (int) – the number of layer
delete(cat=None, layer=1)[source]

If cat is given delete cat from line_cats structure (using Vect_field_cat_del) else delete all categories of given layer (using Vect_cat_del).

Parameters:
  • cat (int) – the cat to add
  • layer (int) – the number of layer
get(layer=1)[source]

Return the first found category of given layer and the number of category found.

Parameters:layer (int) – the number of layer
get_list(layer=1)[source]

Get list of categories of given field.

Parameters:layer (int) – the number of layer
layer[source]
n_cats[source]

Return the number of categories

reset()[source]

Reset the C cats struct from previous values.

set(cat, layer=1)[source]

Add new field/cat to category structure if doesn’t exist yet.

Parameters:
  • cat (int) – the cat to add
  • layer (int) – the number of layer
class pygrass.vector.basic.CatsList(c_cat_list=None)[source]

Bases: object

>>> cats_list = CatsList()
>>> cats_list.min
[]
>>> cats_list.max
[]
>>> cats_list.n_ranges
0
>>> cats_list.layer
0
>>> string = "2,3,5-9,20"
>>> cats_list.from_string(string)
>>> cats_list.min
[2, 3, 5, 20]
>>> cats_list.max
[2, 3, 9, 20]
>>> cats_list.n_ranges
4
from_array(array)[source]

Convert ordered array of integers to cat_list structure.

Parameters:array (array) – the input array containing the cats
from_string(string)[source]

Converts string of categories and cat ranges separated by commas to cat_list.

Parameters:string (str) – a string containing the cats separated by commas
layer[source]

Return the layer number

max[source]

Return the maximum value

min[source]

Return the minimum value

n_ranges[source]

Return the ranges number

class pygrass.vector.basic.Ilist(integer_list=None)[source]

Bases: object

Instantiate a list of integer using the C GRASS struct ilist, the class contains this struct as c_ilist attribute.

append(value)[source]

Append an integer to the list

contains(value)[source]

Check if value is in the list

extend(ilist)[source]

Extend the list with another Ilist object or with a list of integers

Parameters:ilist (a Ilist object) – the ilist to append
remove(value)[source]

Remove a value from a list

reset()[source]

Reset the list

pygrass.vector.find module

Created on Tue Mar 19 11:09:30 2013

@author: pietro

class pygrass.vector.find.AbstractFinder(c_mapinfo, table=None, writable=False)[source]

Bases: object

is_open()[source]

Check if the vector map is open or not

class pygrass.vector.find.BboxFinder(c_mapinfo, table=None, writable=False)[source]

Bases: pygrass.vector.find.AbstractFinder

areas(*args, **kargs)[source]

Find the nearest area. Vect_find_area

geos(*args, **kargs)[source]

Find the geometry features contained in the bbox. Vect_select_lines_by_box

Valid type are all the keys in find.vtype dictionary

islands(*args, **kargs)[source]

Find the nearest island. Vect_find_island

nodes(*args, **kargs)[source]

Find the nearest area. Vect_find_area

class pygrass.vector.find.PointFinder(c_mapinfo, table=None, writable=False)[source]

Bases: pygrass.vector.find.AbstractFinder

PointFinder

Find the geomtry features of a vector map that are close to a point.

>>> from grass.pygrass.vector import VectorTopo
>>> zipcodes = VectorTopo('zipcodes', 'PERMANENT')
>>> schools = VectorTopo('schools', 'PERMANENT')
>>> zipcodes.open('r')
>>> schools.open('r')
>>> result = []
>>> for school in schools:
...     zipcode = zipcodes.find['by_point'].area(school)
...     result.append((school.attrs['NAMESHORT'],
...                    zipcode.attrs['ZIPCODE']))
...
>>> result[0]
(u'SWIFT CREEK', u'RALEIGH 27606')
>>> result[1]
(u'BRIARCLIFF', u'CARY 27511')
>>> result[2]
(u'FARMINGTON WOODS', u'CARY 27511')
>>> from grass.pygrass.vector.geometry import Point
>>> pnt = Point(631213.349291, 224684.900084)
>>> school = schools.find['by_point'].geo(pnt, maxdist=300.)
>>> school.attrs['NAMELONG']
u'ADAMS ELEMENTARY'
>>> for school in schools.find['by_point'].geos(pnt, maxdist=1000.):
...     print school.attrs['NAMELONG']
...
CARY HIGH
EAST CARY MIDDLE SITE
ADAMS ELEMENTARY
>>> schools.close()
>>> zipcodes.close()
area(*args, **kargs)[source]

Find the nearest area. Vect_find_area

geo(*args, **kargs)[source]

Find the nearest line. Vect_find_line

Valid type are all the keys in find.vtype dictionary

geos(*args, **kargs)[source]

Find the nearest line. Vect_find_line_list

Valid type are all the keys in find.vtype dictionary

island(*args, **kargs)[source]

Find the nearest island. Vect_find_island

class pygrass.vector.find.PolygonFinder(c_mapinfo, table=None, writable=False)[source]

Bases: pygrass.vector.find.AbstractFinder

areas(polygon, isles=None)[source]
lines(polygon, isles=None)[source]

pygrass.vector.geometry module

Created on Wed Jul 18 10:46:25 2012

@author: pietro

class pygrass.vector.geometry.Area(boundary=None, centroid=None, isles=None, **kargs)[source]

Bases: pygrass.vector.geometry.Geo

Vect_build_line_area, Vect_find_area, Vect_get_area_box, Vect_get_area_points_geos, Vect_get_centroid_area,

Vect_get_isle_area, Vect_get_line_areas, Vect_get_num_areas, Vect_get_point_in_area, Vect_isle_find_area, Vect_point_in_area, Vect_point_in_area_outer_ring,

Vect_read_area_geos, Vect_remove_small_areas, Vect_select_areas_by_box, Vect_select_areas_by_polygon

alive()[source]

Check if area is alive or dead (topology required)

area()[source]

Returns area of area without areas of isles. double Vect_get_area_area (const struct Map_info *Map, int area)

bbox(bbox=None)[source]

Return the Bbox of area

Parameters:bbox (a Bbox object) – a Bbox object to fill with info from bounding box of area
boundaries(ilist=False)[source]

Creates list of boundaries for given area.

int Vect_get_area_boundaries(const struct Map_info *Map,
int area, struct ilist *List)
buffer(dist=None, dist_x=None, dist_y=None, angle=0, round_=True, caps=True, tol=0.1)[source]

Return the buffer area around the area, using the Vect_area_buffer2 C function.

Parameters:
  • dist (num) – the distance around the area
  • dist_x (num) – the distance along x
  • dist_y (num) – the distance along y
  • angle (num) – the angle between 0x and major axis
  • round (bool) – to make corners round
  • tol (float) – fix the maximum distance between theoretical arc and output segments
Returns:

the buffer as Area object

cats(cats=None)[source]

Get area categories.

Parameters:cats (a Cats object) – a Cats object to fill with info with area categories
contain_pnt(pnt, bbox=None)[source]

Check if point is in area.

Parameters:
  • pnt (a Point object or a tuple with the coordinates) – the point to analyze
  • bbox (a Bbox object) – the bounding box where run the analysis
get_centroid(centroid=None)[source]

Return the centroid

Parameters:centroid (a Centroid object) – a Centroid object to fill with info from centroid of area
get_first_cat()[source]

Find FIRST category of given field and area.

int Vect_get_area_cat(const struct Map_info *Map, int area, int field)

get_isles(isles=None)[source]

Instantiate the boundary attribute reading area_id

get_points(line=None)[source]

Return a Line object with the outer ring

Parameters:line (a Line object) – a Line object to fill with info from points of area
gtype = 64
init_from_id(area_id=None)[source]

Return an Area object

num_isles()[source]
perimeter()[source]

Calculate area perimeter.

Returns:double Vect_area_perimeter (const struct line_pnts *Points)
read(line=None, centroid=None, isles=None)[source]
class pygrass.vector.geometry.Attrs(cat, table, writable=False)[source]

Bases: object

cat

Set and obtain cat value

commit()[source]

Save the changes

keys()[source]

Return the column name of the attribute table. >>> from grass.pygrass.vector import VectorTopo >>> schools = VectorTopo(‘schools’) >>> schools.open(‘r’) >>> school = schools[1] >>> attrs = Attrs(school.cat, schools.table) >>> attrs.keys() # doctest: +ELLIPSIS +NORMALIZE_WHITESPACE [u’cat’, ... u’NOTES’]

values()[source]

Return the values of the attribute table row. >>> from grass.pygrass.vector import VectorTopo >>> schools = VectorTopo(‘schools’) >>> schools.open(‘r’) >>> school = schools[1] >>> attrs = Attrs(school.cat, schools.table) >>> attrs.values() # doctest: +ELLIPSIS +NORMALIZE_WHITESPACE (1, ... None)

class pygrass.vector.geometry.Boundary(lines=None, left=None, right=None, **kargs)[source]

Bases: pygrass.vector.geometry.Line

area()[source]

Return the area of the polygon.

>>> bound = Boundary(points=[(0, 0), (0, 2), (2, 2), (2, 0),
...                          (0, 0)])
>>> bound.area()
4.0
get_left_centroid(idonly=False)[source]

Return left value

Parameters:idonly (bool) – True to return only the cat of feature
get_left_right()[source]

Return left and right value

get_right_centroid(idonly=False)[source]

Return right value

Parameters:idonly (bool) – True to return only the cat of feature
gtype = 4
left_id[source]
right_id[source]
class pygrass.vector.geometry.Centroid(area_id=None, **kargs)[source]

Bases: pygrass.vector.geometry.Point

The Centroid class inherit from the Point class. Centroid contains an attribute with the C Map_info struct, and attributes with the id of the Area.

>>> centroid = Centroid(x=0, y=10)
>>> centroid
Centoid(0.000000, 10.000000)
>>> from grass.pygrass.vector import VectorTopo
>>> geo = VectorTopo('geology')
>>> geo.open(mode='r')
>>> centroid = Centroid(v_id=1, c_mapinfo=geo.c_mapinfo)
>>> centroid
Centoid(893202.874416, 297339.312795)
get_area_id()[source]

Return the area_id, using the c_mapinfo and an centroid_id attributes of the class, and calling the Vect_get_centroid_area C function, if no area_id were found return None

get_centroid_id()[source]

Return the centroid_id, using the c_mapinfo and an area_id attributes of the class, and calling the Vect_get_area_centroid C function, if no centroid_id were found return None

gtype = 8
class pygrass.vector.geometry.Geo(v_id=0, c_mapinfo=None, c_points=None, c_cats=None, table=None, writable=False, is2D=True)[source]

Bases: object

>>> geo0 = Geo()
>>> points = ctypes.pointer(libvect.line_pnts())
>>> cats = ctypes.pointer(libvect.line_cats())
>>> geo1 = Geo(c_points=points, c_cats=cats)
cat[source]
gtype = None
is_with_topology()[source]
read()[source]

Read and set the coordinates of the centroid from the vector map, using the centroid_id and calling the Vect_read_line C function

class pygrass.vector.geometry.Isle(**kargs)[source]

Bases: pygrass.vector.geometry.Geo

An Isle is an area contained by another area.

alive()[source]

Check if isle is alive or dead (topology required)

area()[source]

Return the area value of an Isle

area_id()[source]

Returns area id for isle.

bbox(bbox=None)[source]

Return bounding box of Isle

boundaries()[source]

Return a list of boundaries

contain_pnt(pnt)[source]

Check if point is in area.

Parameters:pnt (a Point object or a tuple with the coordinates) – the point to remove
perimeter()[source]

Return the perimeter value of an Isle.

points()[source]

Return a Line object with the outer ring points

points_geos()[source]

Return a Line object with the outer ring points

class pygrass.vector.geometry.Isles(c_mapinfo, area_id=None)[source]

Bases: object

get_isles()[source]

Return isles

get_isles_id()[source]

Return the id of isles

select_by_bbox(bbox)[source]

Vect_select_isles_by_box

Warning

Not implemented yet.

class pygrass.vector.geometry.Line(points=None, **kargs)[source]

Bases: pygrass.vector.geometry.Geo

Instantiate a new Line with a list of tuple, or with a list of Point.

>>> line = Line([(0, 0), (1, 1), (2, 0), (1, -1)])
>>> line                               
Line([Point(0.000000, 0.000000),
      Point(1.000000, 1.000000),
      Point(2.000000, 0.000000),
      Point(1.000000, -1.000000)])
append(pnt)[source]

Appends one point to the end of a line, using the Vect_append_point C function.

Parameters:pnt – the point to add to line

Like python list.

bbox(bbox=None)[source]

Return the bounding box of the line, using Vect_line_box C function.

>>> line = Line([(0, 0), (0, 1), (2, 1), (2, 0)])
>>> bbox = line.bbox()
>>> bbox
Bbox(1.0, 0.0, 2.0, 0.0)
buffer(dist=None, dist_x=None, dist_y=None, angle=0, round_=True, caps=True, tol=0.1)[source]

Return the buffer area around the line, using the Vect_line_buffer2 C function.

Parameters:
  • dist (num) – the distance around the line
  • dist_x (num) – the distance along x
  • dist_y (num) – the distance along y
  • angle (num) – the angle between 0x and major axis
  • round (bool) – to make corners round
  • tol (float) – fix the maximum distance between theoretical arc and output segments
Returns:

the buffer as Area object

>>> line = Line([(0, 0), (0, 2)])
>>> area = line.buffer(10)
>>> area.boundary                              
Line([Point(-10.000000, 0.000000),...Point(-10.000000, 0.000000)])
>>> area.centroid
Point(0.000000, 0.000000)
>>> area.isles
[]
delete(indx)[source]

Remove the point in the index position. :param indx: the index where add new point :type indx: int

>>> line = Line([(0, 0), (1, 1), (2, 2)])
>>> line.delete(-1)
>>> line
Line([Point(0.000000, 0.000000), Point(1.000000, 1.000000)])
distance(pnt)[source]

Calculate the distance between line and a point.

Parameters:pnt (a Point object or a tuple with the coordinates) – the point to calculate distance

Return a namedtuple with:

  • point: the closest point on the line,
  • dist: the distance between these two points,
  • spdist: distance to point on line from segment beginning
  • sldist: distance to point on line form line beginning along line

The distance is compute using the Vect_line_distance C function.

>>> point = Point(2.3, 0.5)
>>> line = Line([(0, 0), (2, 0), (3, 0)])
>>> line.distance(point)           
LineDist(point=Point(2.300000, 0.000000),
         dist=0.5, spdist=0.2999999999999998, sldist=2.3)
extend(line, forward=True)[source]

Appends points to the end of a line.

Parameters:
  • line (Line object ot list of points) – it is possible to extend a line, give a list of points, or directly with a line_pnts struct.
  • forward – if forward is True the line is extend forward otherwise is extend backward. The method use the Vect_append_points C function.
from_wkt(wkt)[source]

Create a line reading a WKT string.

Parameters:wkt – the WKT string containing the LINESTRING
get_first_cat()[source]

Fetches FIRST category number for given vector line and field, using the Vect_get_line_cat C function.

Warning

Not implemented yet.

get_pnt(distance, angle=0, slope=0)[source]

Return a Point object on line in the specified distance, using the Vect_point_on_line C function. Raise a ValueError If the distance exceed the Line length.

>>> line = Line([(0, 0), (1, 1)])
>>> line.get_pnt(5)      
Traceback (most recent call last):
    ...
ValueError: The distance exceed the length of the line,
that is: 1.414214
>>> line.get_pnt(1)
Point(0.707107, 0.707107)
Traceback (most recent call last):
    ...
ValueError: The distance exceed the length of the line,
get_wkb()[source]

Return a WKB buffer.

Warning

Not implemented yet.

get_wkt()[source]

Return a Well Known Text string of the line.

>>> line = Line([(0, 0), (1, 1), (1, 2)])
>>> line.get_wkt()                 
'LINESTRING(0.000000 0.000000, ..., 1.000000 2.000000)'
gtype = 2
insert(indx, pnt)[source]

Insert new point at index position and move all old points at that position and above up, using Vect_line_insert_point C function.

Parameters:
  • indx (int) – the index where add new point
  • pnt – the point to add
length()[source]

Calculate line length, 3D-length in case of 3D vector line, using Vect_line_length C function.

>>> line = Line([(0, 0), (1, 1), (0, 1)])
>>> line.length()
2.414213562373095
length_geodesic()[source]

Calculate line length, usig Vect_line_geodesic_length C function.

>>> line = Line([(0, 0), (1, 1), (0, 1)])
>>> line.length_geodesic()
2.414213562373095
nodes()[source]

Return the nodes in the line

pop(indx)[source]

Return the point in the index position and remove from the Line.

Parameters:indx – the index where add new point
prune()[source]

Remove duplicate points, i.e. zero length segments, using Vect_line_prune C function.

>>> line = Line([(0, 0), (1, 1), (1, 1), (2, 2)])
>>> line.prune()
>>> line                           
Line([Point(0.000000, 0.000000),
      Point(1.000000, 1.000000),
      Point(2.000000, 2.000000)])
prune_thresh(threshold)[source]

Remove points in threshold, using the Vect_line_prune_thresh C funtion.

Parameters:threshold – the threshold value where prune points

Warning

prune_thresh is not working yet.

remove(pnt)[source]

Delete point at given index and move all points above down, using Vect_line_delete_point C function.

Parameters:pnt – the point to remove
reset()[source]

Reset line, using Vect_reset_line C function.

>>> line = Line([(0, 0), (1, 1), (2, 0), (1, -1)])
>>> len(line)
4
>>> line.reset()
>>> len(line)
0
>>> line
Line([])
reverse()[source]

Reverse the order of vertices, using Vect_line_reverse C function.

>>> line = Line([(0, 0), (1, 1), (2, 2)])
>>> line.reverse()
>>> line                           
Line([Point(2.000000, 2.000000),
      Point(1.000000, 1.000000),
      Point(0.000000, 0.000000)])
segment(start, end)[source]

Create line segment. using the Vect_line_segment C function.

Parameters:
  • start (float) – distance from the begining of the line where the segment start
  • end (float) – distance from the begining of the line where the segment end
::

# x (1, 1) # | # |- # | # x——–x (1, 0) # (0, 0) ^

>>> line = Line([(0, 0), (1, 0), (1, 1)])
>>> line.segment(0.5, 1.5)         
Line([Point(0.500000, 0.000000),
      Point(1.000000, 0.000000),
      Point(1.000000, 0.500000)])
toarray()[source]

Return an array of coordinates.

>>> line = Line([(0, 0), (1, 1), (2, 0), (1, -1)])
>>> line.toarray()                 
array([[ 0.,  0.],
       [ 1.,  1.],
       [ 2.,  0.],
       [ 1., -1.]])
tolist()[source]

Return a list of tuple.

>>> line = Line([(0, 0), (1, 1), (2, 0), (1, -1)])
>>> line.tolist()
[(0.0, 0.0), (1.0, 1.0), (2.0, 0.0), (1.0, -1.0)]
class pygrass.vector.geometry.LineDist

Bases: tuple

LineDist(point, dist, spdist, sldist)

dist

Alias for field number 1

point

Alias for field number 0

sldist

Alias for field number 3

spdist

Alias for field number 2

class pygrass.vector.geometry.Node(v_id, c_mapinfo)[source]

Bases: object

angles()[source]

Return a generator with all lines angles in a node.

coords()[source]

Return a tuple with the node coordinates.

ilines(only_in=False, only_out=False)[source]

Return a generator with all lines id connected to a node. The line id is negative if line is ending on the node and positive if starting from the node.

Parameters:
  • only_in (bool) – Return only the lines that are ending in the node
  • only_out (bool) – Return only the lines that are starting in the node
lines(only_in=False, only_out=False)[source]

Return a generator with all lines connected to a node.

Parameters:
  • only_in (bool) – Return only the lines that are ending in the node
  • only_out (bool) – Return only the lines that are starting in the node
class pygrass.vector.geometry.Point(x=0, y=0, z=None, **kargs)[source]

Bases: pygrass.vector.geometry.Geo

Instantiate a Point object that could be 2 or 3D, default parameters are 0.

>>> pnt = Point()
>>> pnt.x
0.0
>>> pnt.y
0.0
>>> pnt.z
>>> pnt.is2D
True
>>> pnt
Point(0.000000, 0.000000)
>>> pnt.z = 0
>>> pnt.is2D
False
>>> pnt
Point(0.000000, 0.000000, 0.000000)
>>> print(pnt)
POINT(0.000000 0.000000 0.000000)
buffer(dist=None, dist_x=None, dist_y=None, angle=0, round_=True, tol=0.1)[source]

Return the buffer area around the point, using the Vect_point_buffer2 C function.

Parameters:
  • dist (num) – the distance around the point
  • dist_x (num) – the distance along x
  • dist_y (num) – the distance along y
  • angle (num) – the angle between 0x and major axis
  • round (bool) – to make corners round
  • tol (float) – fix the maximum distance between theoretical arc and output segments
Returns:

the buffer as Area object

>>> pnt = Point(0, 0)
>>> area = pnt.buffer(10)
>>> area.boundary                              
Line([Point(10.000000, 0.000000),...Point(10.000000, 0.000000)])
>>> area.centroid
Point(0.000000, 0.000000)
>>> area.isles
[]
coords()[source]

Return a tuple with the point coordinates.

>>> pnt = Point(10, 100)
>>> pnt.coords()
(10.0, 100.0)

If the point is 2D return a x, y tuple. But if we change the z the Point object become a 3D point, therefore the method return a x, y, z tuple.

>>> pnt.z = 1000.
>>> pnt.coords()
(10.0, 100.0, 1000.0)
distance(pnt)[source]

Calculate distance of 2 points, using the Vect_points_distance C function, If one of the point have z == None, return the 2D distance.

Parameters:pnt – the point for calculate the distance
get_wkb()[source]

Return a “well know binary” (WKB) geometry buffer

Warning

Not implemented yet.

get_wkt()[source]

Return a “well know text” (WKT) geometry string.

>>> pnt = Point(10, 100)
>>> pnt.get_wkt()
'POINT(10.000000 100.000000)'

Warning

Only POINT (2/3D) are supported, POINTM and POINT with: XYZM are not supported yet.

gtype = 1
x

Set and obtain x coordinate

y

Set and obtain y coordinate

z

Set and obtain z coordinate

pygrass.vector.geometry.c_read_line(feature_id, c_mapinfo, c_points, c_cats)[source]
pygrass.vector.geometry.c_read_next_line(c_mapinfo, c_points, c_cats)[source]
pygrass.vector.geometry.get_xyz(pnt)[source]

Return a tuple with: x, y, z.

>>> pnt = Point(0, 0)
>>> get_xyz(pnt)
(0.0, 0.0, 0.0)
>>> get_xyz((1, 1))
(1, 1, 0.0)
>>> get_xyz((1, 1, 2))
(1, 1, 2)
>>> get_xyz((1, 1, 2, 2))                          
Traceback (most recent call last):
    ...
ValueError: The the format of the point is not supported: (1, 1, 2, 2)
Traceback (most recent call last):
    ...
ValueError: The the format of the point is not supported: (1, 1, 2, 2)
pygrass.vector.geometry.intersects(lineA, lineB, with_z=False)[source]

Return a list of points

>>> lineA = Line([(0, 0), (4, 0)])
>>> lineB = Line([(2, 2), (2, -2)])
>>> intersects(lineA, lineB)
Line([Point(2.000000, 0.000000)])
pygrass.vector.geometry.read_WKB(buff)[source]

Read the binary buffer and return a geometry object

pygrass.vector.geometry.read_WKT(string)[source]

Read the string and return a geometry object

WKT:

POINT(0 0)
LINESTRING(0 0,1 1,1 2)
POLYGON((0 0,4 0,4 4,0 4,0 0),(1 1, 2 1, 2 2, 1 2,1 1))
MULTIPOINT(0 0,1 2)
MULTILINESTRING((0 0,1 1,1 2),(2 3,3 2,5 4))
MULTIPOLYGON(((0 0,4 0,4 4,0 4,0 0),(1 1,2 1,2 2,1 2,1 1)),
             ((-1 -1,-1 -2,-2 -2,-2 -1,-1 -1)))
GEOMETRYCOLLECTION(POINT(2 3),LINESTRING(2 3,3 4))

EWKT:

POINT(0 0 0) -- XYZ
SRID=32632;POINT(0 0) -- XY with SRID
POINTM(0 0 0) -- XYM
POINT(0 0 0 0) -- XYZM
SRID=4326;MULTIPOINTM(0 0 0,1 2 1) -- XYM with SRID
MULTILINESTRING((0 0 0,1 1 0,1 2 1),(2 3 1,3 2 1,5 4 1))
POLYGON((0 0 0,4 0 0,4 4 0,0 4 0,0 0 0),(1 1 0,2 1 0,2 2 0,1 2 0,1 1 0))
MULTIPOLYGON(((0 0 0,4 0 0,4 4 0,0 4 0,0 0 0),
              (1 1 0,2 1 0,2 2 0,1 2 0,1 1 0)),
             ((-1 -1 0,-1 -2 0,-2 -2 0,-2 -1 0,-1 -1 0)))
GEOMETRYCOLLECTIONM( POINTM(2 3 9), LINESTRINGM(2 3 4, 3 4 5) )
MULTICURVE( (0 0, 5 5), CIRCULARSTRING(4 0, 4 4, 8 4) )
POLYHEDRALSURFACE( ((0 0 0, 0 0 1, 0 1 1, 0 1 0, 0 0 0)),
                   ((0 0 0, 0 1 0, 1 1 0, 1 0 0, 0 0 0)),
                   ((0 0 0, 1 0 0, 1 0 1, 0 0 1, 0 0 0)),
                   ((1 1 0, 1 1 1, 1 0 1, 1 0 0, 1 1 0)),
                   ((0 1 0, 0 1 1, 1 1 1, 1 1 0, 0 1 0)),
                   ((0 0 1, 1 0 1, 1 1 1, 0 1 1, 0 0 1)) )
TRIANGLE ((0 0, 0 9, 9 0, 0 0))
TIN( ((0 0 0, 0 0 1, 0 1 0, 0 0 0)), ((0 0 0, 0 1 0, 1 1 0, 0 0 0)) )
pygrass.vector.geometry.read_line(feature_id, c_mapinfo, table=None, writable=False, c_points=None, c_cats=None, is2D=True)[source]

Return a geometry object given the feature id and the c_mapinfo.

pygrass.vector.geometry.read_next_line(c_mapinfo, table=None, writable=False, c_points=None, c_cats=None, is2D=True)[source]

Return the next geometry feature of a vector map.

pygrass.vector.sql module

It is a collection of strings to avoid to repeat the code.

>>> SELECT.format(cols=', '.join(['cat', 'area']), tname='table')
'SELECT cat, area FROM table;'
>>> SELECT_WHERE.format(cols=', '.join(['cat', 'area']),
...                     tname='table', condition='area>10000')
'SELECT cat, area FROM table WHERE area>10000;'

pygrass.vector.table module

Created on Wed Aug 8 15:29:21 2012

@author: pietro

class pygrass.vector.table.Columns(tname, connection, key=u'cat')[source]

Bases: object

Object to work with columns table.

It is possible to instantiate a Columns object given the table name and the database connection.

For a sqlite table:

>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> cols_sqlite = Columns('census',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.tname
u'census'

For a postgreSQL table:

>>> import psycopg2 as pg                              
>>> cols_pg = Columns('boundary_municp_pg',
...                   pg.connect('host=localhost dbname=grassdb')) 
>>> cols_pg.tname 
'boundary_municp_pg'                                   
add(col_name, col_type)[source]

Add a new column to the table.

Parameters:
  • col_name (str) – the name of column to add
  • col_type (str) – the tipe of column to add
>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/$MAPSET/sqlite/sqlite.db'
>>> from grass.pygrass.utils import copy, remove
>>> copy('census','mycensus','vect')
>>> cols_sqlite = Columns('mycensus',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.add(['n_pizza'], ['INT'])
>>> 'n_pizza' in cols_sqlite
True
>>> import psycopg2 as pg                         
>>> cols_pg = Columns('boundary_municp_pg',
...                   pg.connect('host=localhost dbname=grassdb'))  
>>> cols_pg.add('n_pizza', 'INT')                 
>>> 'n_pizza' in cols_pg                          
True
>>> remove('mycensus', 'vect')
cast(col_name, new_type)[source]

Change the column type.

Parameters:
  • col_name (str) – the name of column
  • new_type (str) – the new type of column
>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/$MAPSET/sqlite/sqlite.db'
>>> from grass.pygrass.utils import copy, remove
>>> copy('census','mycensus','vect')
>>> cols_sqlite = Columns('mycensus',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.add(['n_pizzas'], ['INT'])
>>> cols_sqlite.cast('n_pizzas', 'float8')  
Traceback (most recent call last):
  ...
DBError: SQLite does not support to cast columns.
>>> import psycopg2 as pg                         
>>> cols_pg = Columns('boundary_municp_pg',
...                   pg.connect('host=localhost dbname=grassdb')) 
>>> cols_pg.cast('n_pizzas', 'float8')            
>>> cols_pg['n_pizzas']                           
'float8'
>>> remove('mycensus', 'vect')
Traceback (most recent call last):
  ...
DBError: SQLite does not support to cast columns.

Warning

It is not possible to cast a column with sqlite

drop(col_name)[source]

Drop a column from the table.

Parameters:col_name (str) – the name of column to remove
>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/$MAPSET/sqlite/sqlite.db'
>>> from grass.pygrass.utils import copy, remove
>>> copy('census','mycensus','vect')
>>> cols_sqlite = Columns('mycensus',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.drop('CHILD')                 
>>> 'CHILD' in cols_sqlite
False
>>> import psycopg2 as pg                         
>>> cols_pg = Columns('boundary_municp_pg',
...                   pg.connect('host=localhost dbname=grassdb')) 
>>> cols_pg.drop('CHILD') 
>>> 'CHILD' in cols_pg 
False
>>> remove('mycensus','vect')
is_pg()[source]

Return True if is a psycopg connection.

>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> cols_sqlite = Columns('census',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.is_pg()
False
>>> import psycopg2 as pg 
>>> cols_pg = Columns('boundary_municp_pg',
...                   pg.connect('host=localhost dbname=grassdb')) 
>>> cols_pg.is_pg() 
True
items()[source]

Return a list of tuple with column name and column type.

>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> cols_sqlite = Columns('census',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.items()                       
[(u'cat', u'integer'), ...]
>>> import psycopg2 as pg                         
>>> cols_pg = Columns('boundary_municp_pg',
...                   pg.connect('host=localhost dbname=grassdb')) 
>>> cols_pg.items()                     
[('cat', 'int4'), ('objectid', 'int4'), ('area', 'float8'), ...]
names(remove=None, unicod=True)[source]

Return a list with the column names. Remove it is used to remove a columns.

>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> cols_sqlite = Columns('census',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.names()                      
[u'cat', u'OBJECTID', u'AREA', u'PERIMETER', ...]
>>> import psycopg2 as pg                         
>>> cols_pg = Columns('boundary_municp_pg',       
...                   pg.connect('host=localhost dbname=grassdb'))
>>> cols_pg.names()                     
['cat', 'objectid', 'area', 'perimeter', ...]
rename(old_name, new_name)[source]

Rename a column of the table.

Parameters:
  • old_name (str) – the name of existing column
  • new_name (str) – the name of new column
>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/$MAPSET/sqlite/sqlite.db'
>>> from grass.pygrass.utils import copy, remove
>>> copy('census','mycensus','vect')
>>> cols_sqlite = Columns('mycensus',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.add(['n_pizza'], ['INT'])
>>> 'n_pizza' in cols_sqlite
True
>>> cols_sqlite.rename('n_pizza', 'n_pizzas')  
>>> 'n_pizza' in cols_sqlite
False
>>> 'n_pizzas' in cols_sqlite
True
>>> import psycopg2 as pg                         
>>> cols_pg = Columns('boundary_municp_pg',
...                   pg.connect('host=localhost dbname=grassdb')) 
>>> cols_pg.rename('n_pizza', 'n_pizzas')         
>>> 'n_pizza' in cols_pg                          
False
>>> 'n_pizzas' in cols_pg                         
True
>>> remove('mycensus', 'vect')
sql_descr(remove=None)[source]

Return a string with description of columns. Remove it is used to remove a columns.

>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> cols_sqlite = Columns('census',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.sql_descr()                   
u'cat integer, OBJECTID integer, AREA double precision, ...'
>>> import psycopg2 as pg                         
>>> cols_pg = Columns('boundary_municp_pg',
...                   pg.connect('host=localhost dbname=grassdb')) 
>>> cols_pg.sql_descr()                 
'cat int4, objectid int4, area float8, perimeter float8, ...'
types()[source]

Return a list with the column types.

>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> cols_sqlite = Columns('census',
...                       sqlite3.connect(get_path(path)))
>>> cols_sqlite.types()                       
[u'integer', u'integer', ...]
>>> import psycopg2 as pg                         
>>> cols_pg = Columns('boundary_municp_pg',
...                   pg.connect('host=localhost dbname=grassdb')) 
>>> cols_pg.types()                     
['int4', 'int4', 'float8', 'float8', 'float8', ...]
update_odict()[source]

Read columns name and types from table and update the odict attribute.

Bases: object

Interface containing link to the table DB.

>>> from grass.pygrass.vector import VectorTopo
>>> cens = VectorTopo('census')
>>> cens.open(mode='r')
>>> dblinks = DBlinks(cens.c_mapinfo)
>>> dblinks
DBlinks([Link(1, census, sqlite)])
>>> dblinks[0]
Link(1, census, sqlite)
>>> dblinks['census']
Link(1, census, sqlite)
>>> cens.close()
add(link)[source]

Add a new link. Need to open vector map in write mode

Parameters:link – the Link to add to the DBlinks
by_index(indx)[source]

Return a Link object by index

Parameters:indx (int) – the index where add new point
by_layer(layer)[source]

Return the choosen Link using the layer

Parameters:layer (int) – the number of layer
by_name(name)[source]

Return the choosen Link using the name

Parameters:name (str) – the name of Link
from_name_to_num(name)[source]

Vect_get_field_number

Return the number of DBlinks

remove(key, force=False)[source]

Remove a link. If force set to true remove also the table

Parameters:
  • key (str) – the key of Link
  • force (boole) – if True remove also the table from database otherwise only the link between table and vector
>>> from grass.pygrass.vector import VectorTopo
>>> municip = VectorTopo('census')
>>> municip.open(mode='r')
>>> dblinks = DBlinks(municip.c_mapinfo)
>>> dblinks
DBlinks([Link(1, census, sqlite)])
>>> dblinks.remove('pg_link')                     
>>> dblinks  # need to open vector map in write mode
DBlinks([Link(1, census, sqlite)])
class pygrass.vector.table.Filters(tname)[source]

Bases: object

Help user to build a simple sql query.

>>> filter = Filters('table')
>>> filter.get_sql()
u'SELECT * FROM table;'
>>> filter.where("area<10000").get_sql()
u'SELECT * FROM table WHERE area<10000;'
>>> filter.select("cat", "area").get_sql()
u'SELECT cat, area FROM table WHERE area<10000;'
>>> filter.order_by("area").limit(10).get_sql()
u'SELECT cat, area FROM table WHERE area<10000 ORDER BY area LIMIT 10;'
get_sql()[source]

Return the SQL query

group_by(*groupby)[source]

Create the group by condition

Parameters:groupby (str, list) – the name of column/s to group the result
limit(number)[source]

Create the limit condition

Parameters:number (int) – the number to limit the result
order_by(*orderby)[source]

Create the order by condition

Parameters:orderby (str) – the name of column/s to order the result
reset()[source]

Clean internal variables

select(*args)[source]

Create the select query

where(condition)[source]

Create the where condition

Parameters:condition (str) – the condition of where statement, for example cat = 1

Bases: object

Define a Link between vector map and the attributes table.

It is possible to define a Link object or given all the information (layer, name, table name, key, database, driver):

>>> link = Link(1, 'link0', 'census', 'cat',
...             '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db', 'sqlite')
>>> link.layer
1
>>> link.name
'link0'
>>> link.table_name
'census'
>>> link.key
'cat'
>>> link.database
'$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> link.driver
'sqlite'
>>> link
Link(1, link0, sqlite)

It is possible to change parameters with:

>>> link.driver = 'pg'                                
>>> link.driver                                       
'pg'
>>> link.driver = 'postgres'                
Traceback (most recent call last):
  ...
TypeError: Driver not supported, use: sqlite, pg.
>>> link.driver                                       
'pg'
>>> link.number = 0                         
Traceback (most recent call last):
  ...
TypeError: Number must be positive and greater than 0.
Traceback (most recent call last):
  ...
TypeError: Number must be positive and greater than 0.

Or given a c_fieldinfo object that is a ctypes pointer to the field_info C struct.

>>> link = Link(c_fieldinfo = ctypes.pointer(libvect.field_info()))
connection()[source]

Return a connection object.

>>> link = Link(1, 'link0', 'census', 'cat',
...             '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db',
...             'sqlite')
>>> conn = link.connection()
>>> cur = conn.cursor()
>>> cur.execute("SELECT cat,TOTAL_POP,PERIMETER FROM %s" %
...             link.table_name)              
<sqlite3.Cursor object at ...>
>>> cur.fetchone()
(1, 44, 757.669)
>>> cur.close()
>>> conn.close()
database

Set and obtain database value

driver

Set and obtain driver value. The drivers supported by PyGRASS are: SQLite and PostgreSQL

info()[source]

Print information of the link.

>>> link = Link(1, 'link0', 'census', 'cat',
...             '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db',
...             'sqlite')
>>> link.info()
layer:     1
name:      link0
table:     census
key:       cat
database:  $GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db
driver:    sqlite
key

Set and obtain cat value

layer

Set and obtain layer number

name

Set and obtain name vale

table()[source]

Return a Table object.

>>> link = Link(1, 'link0', 'census', 'cat',
...             '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db',
...             'sqlite')
>>> table = link.table()
>>> table.filters.select('cat', 'TOTAL_POP', 'PERIMETER')
Filters(u'SELECT cat, TOTAL_POP, PERIMETER FROM census;')
>>> cur = table.execute()
>>> cur.fetchone()
(1, 44, 757.669)
>>> cur.close()
table_name

Set and obtain table name value

class pygrass.vector.table.Table(name, connection, key=u'cat')[source]

Bases: object

>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> tab_sqlite = Table(name='census',
...                    connection=sqlite3.connect(get_path(path)))
>>> tab_sqlite.name
u'census'
>>> import psycopg2                                   
>>> tab_pg = Table('boundary_municp_pg',
...                psycopg2.connect('host=localhost dbname=grassdb',
...                                 'pg'))            
>>> tab_pg.columns                          
Columns([('cat', 'int4'), ...])
create(cols, name=None, overwrite=False, cursor=None)[source]

Create a new table

Parameters:
  • cols
  • name (str) – the name of table to create, None for the name of Table object
  • overwrite (bool) – overwrite existing table
  • cursor (Cursor object) – the cursor to connect, if None it use the cursor of connection table object
drop(cursor=None, force=False)[source]

Method to drop table from database

Parameters:
  • cursor (Cursor object) – the cursor to connect, if None it use the cursor of connection table object
  • force (bool) – True to remove the table, by default False to print advice
execute(sql_code=None, cursor=None, many=False, values=None)[source]

Execute SQL code from a given string or build with filters and return a cursor object.

Parameters:
  • sql_code (str) – the SQL code to execute, if not pass it use filters variable
  • cursor (Cursor object) – the cursor to connect, if None it use the cursor of connection table object
  • many (bool) – True to run executemany function
  • values (list of tuple) – The values to substitute into sql_code string
>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> tab_sqlite = Table(name='census',
...                    connection=sqlite3.connect(get_path(path)))
>>> tab_sqlite.filters.select('cat', 'TOTAL_POP').order_by('AREA')
Filters(u'SELECT cat, TOTAL_POP FROM census ORDER BY AREA;')
>>> cur = tab_sqlite.execute()
>>> cur.fetchone()
(1856, 0)
exist(cursor=None)[source]

Return True if the table already exist in the DB, False otherwise

Parameters:cursor – the cursor to connect, if None it use the cursor of connection table object
insert(values, cursor=None, many=False)[source]

Insert a new row

Parameters:
  • values (tuple) – a tuple of values to insert, it is possible to insert more rows using a list of tuple and parameter many
  • cursor (Cursor object) – the cursor to connect, if None it use the cursor of connection table object
  • many (bool) – True to run executemany function
n_rows()[source]

Return the number of rows

>>> import sqlite3
>>> path = '$GISDBASE/$LOCATION_NAME/PERMANENT/sqlite/sqlite.db'
>>> tab_sqlite = Table(name='census',
...                    connection=sqlite3.connect(get_path(path)))
>>> tab_sqlite.n_rows()
2537
name

Set and obtain table name

update(key, values, cursor=None)[source]

Update a table row

Parameters:
  • key (int) – the rowid
  • values (list) – the values to insert without row id. For example if we have a table with four columns: cat, c0, c1, c2 the values list should containing only c0, c1, c2 values.
  • cursor (Cursor object) – the cursor to connect, if None it use the cursor of connection table object
pygrass.vector.table.get_path(path)[source]

Return the full path to the database; replacing environment variable with real values

>>> path = '$GISDBASE/$LOCATION_NAME/$MAPSET/sqlite/sqlite.db'
>>> new_path = get_path(path)
>>> from grass.script.core import gisenv
>>> import os
>>> new_path2 = os.path.join(gisenv()['GISDBASE'], gisenv()['LOCATION_NAME'],
...                          gisenv()['MAPSET'], 'sqlite', 'sqlite.db')
>>> new_path == new_path2
True

pygrass.vector.vector_type module

Created on Wed Jul 18 10:49:26 2012

@author: pietro

Module contents

class pygrass.vector.Vector(name, mapset='', *args, **kwargs)[source]

Bases: grass.pygrass.vector.abstract.Info

Vector class is the grass vector format without topology

>>> from grass.pygrass.vector import Vector
>>> cens = Vector('census')
>>> cens.is_open()
False
>>> cens.mapset
''
>>> cens.exist()
True
>>> cens.mapset
'PERMANENT'
>>> cens.overwrite
False
has_color_table(*args, **kargs)[source]

Return if vector has color table associated in file system; Color table stored in the vector’s attribute table well be not checked

>>> cens = Vector('census')
>>> cens.open(mode='r')
>>> cens.has_color_table()
False
>>> cens.close()
>>> from grass.pygrass.utils import copy, remove
>>> copy('census','mycensus','vect')
>>> from grass.pygrass.modules.shortcuts import vector as v
>>> v.colors(map='mycensus', color='population', column='TOTAL_POP')
Module('v.colors')
>>> mycens = Vector('mycensus')
>>> mycens.open(mode='r')
>>> mycens.has_color_table()
True
>>> mycens.close()
>>> remove('mycensus', 'vect')
next(*args, **kargs)[source]
>>> cens = Vector('census')
>>> cens.open(mode='r')
>>> cens.next()
Boundary(v_id=None)
>>> cens.next()
Boundary(v_id=None)
>>> cens.close()
rewind(*args, **kargs)[source]

Rewind vector map to cause reads to start at beginning.

write(*args, **kargs)[source]

Write geometry features and attributes.

Parameters:
  • geo_obj (geometry GRASS object) – a geometry grass object define in grass.pygrass.vector.geometry
  • attrs (list) – a list with the values that will be insert in the attribute table.
  • set_cats (bool) – if True, the category of the geometry feature is set using the default layer of the vector map and a progressive category value (default), otherwise the c_cats attribute of the geometry object will be used.

Open a new vector map

>>> new = VectorTopo('newvect')
>>> new.exist()
False

define the new columns of the attribute table

>>> cols = [(u'cat',       'INTEGER PRIMARY KEY'),
...         (u'name',      'TEXT')]

open the vector map in write mode

>>> new.open('w', tab_name='newvect', tab_cols=cols)

import a geometry feature

>>> from grass.pygrass.vector.geometry import Point

create two points

>>> point0 = Point(636981.336043, 256517.602235)
>>> point1 = Point(637209.083058, 257970.129540)

then write the two points on the map, with

>>> new.write(point0, ('pub', ))
>>> new.write(point1, ('resturnat', ))

commit the db changes

>>> new.table.conn.commit()
>>> new.table.execute().fetchall()
[(1, u'pub'), (2, u'resturnat')]

close the vector map

>>> new.close()
>>> new.exist()
True

then play with the map

>>> new.open(mode='r')
>>> new.read(1)
Point(636981.336043, 256517.602235)
>>> new.read(2)
Point(637209.083058, 257970.129540)
>>> new.read(1).attrs['name']
u'pub'
>>> new.read(2).attrs['name']
u'resturnat'
>>> new.close()
>>> new.remove()
class pygrass.vector.VectorTopo(name, mapset='', *args, **kwargs)[source]

Bases: pygrass.vector.Vector

Vector class with the support of the GRASS topology.

Open a vector map using the with statement:

>>> with VectorTopo('schools', mode='r') as schools:
...     for school in schools[:3]:
...         print school.attrs['NAMESHORT']
...
SWIFT CREEK
BRIARCLIFF
FARMINGTON WOODS
>>> schools.is_open()
False
bbox(*args, **kargs)[source]

Return the BBox of the vecor map

cat(*args, **kargs)[source]

Return the geometry features with category == cat_id.

Parameters:
  • cat_id (int) – the category number
  • vtype (str) – the type of geometry feature that we are looking for
  • layer (int) – the layer number that will be used
  • generator (bool) – if True return a generator otherwise it return a list of features
close(build=True, release=True)[source]

Close the VectorTopo map, if release is True, the memory occupied by spatial index is released

delete(*args, **kargs)[source]

Remove a feature by its id

Parameters:feature_id (int) – the id of the feature
is_empty(*args, **kargs)[source]

Return if a vector map is empty or not

num_primitive_of(*args, **kargs)[source]

Return the number of primitive

Parameters:primitive (str) –

the name of primitive to query; the supported values are:

  • boundary,
  • centroid,
  • face,
  • kernel,
  • line,
  • point
  • area
  • volume
>>> cens = VectorTopo('census')
>>> cens.open(mode='r')
>>> cens.num_primitive_of('point')
0
>>> cens.num_primitive_of('line')
0
>>> cens.num_primitive_of('centroid')
2537
>>> cens.num_primitive_of('boundary')
6383
>>> cens.close()
num_primitives(*args, **kargs)[source]

Return dictionary with the number of all primitives

number_of(*args, **kargs)[source]

Return the number of the choosen element type

Parameters:vtype – the name of type to query; the supported values are: areas, dblinks, faces, holes, islands, kernels, line_points, lines, nodes, update_lines, update_nodes, volumes
read(*args, **kargs)[source]

Return a geometry object given the feature id.

Parameters:feature_id (int) – the id of feature to obtain
>>> cens = VectorTopo('census')
>>> cens.open(mode='r')
>>> feature1 = cens.read(0)                     
Traceback (most recent call last):
    ...
ValueError: The index must be >0, 0 given.
>>> feature1 = cens.read(1)
>>> feature1
Boundary(v_id=1)
>>> feature1.length()
444.54490917696944
>>> cens.read(-1)
Centoid(642963.159711, 214994.016279)
>>> len(cens)
8920
>>> cens.read(8920)
Centoid(642963.159711, 214994.016279)
>>> cens.read(8921)                             
Traceback (most recent call last):
  ...
IndexError: Index out of range
>>> cens.close()
Traceback (most recent call last):
  ...
IndexError: Index out of range
restore(*args, **kargs)[source]
rewind(*args, **kargs)[source]

Rewind vector map to cause reads to start at beginning.

>>> cens = VectorTopo('census')
>>> cens.open(mode='r')
>>> cens.next()
Boundary(v_id=1)
>>> cens.next()
Boundary(v_id=2)
>>> cens.next()
Boundary(v_id=3)
>>> cens.rewind()
>>> cens.next()
Boundary(v_id=1)
>>> cens.close()
rewrite(*args, **kargs)[source]

Rewrite a geometry features

select_by_bbox(*args, **kargs)[source]

Return the BBox of the vector map

viter(*args, **kargs)[source]

Return an iterator of vector features

Parameters:
  • vtype (str) – the name of type to query; the supported values are: areas, dblinks, faces, holes, islands, kernels, line_points, lines, nodes, update_lines, update_nodes, volumes
  • idonly – variable to return only the id of features instead of full features

to sort the result in a efficient way, use:

>>> from operator import methodcaller as method
>>> big.sort(key=method('area'), reverse=True)  # sort the list
>>> for area in big[:3]:
...     print area, area.area()
Area(2099) 5392751.5304
Area(2171) 4799921.30863
Area(495) 4055812.49695
>>> cens.close()

Note: A new GRASS GIS stable version has been released: GRASS GIS 7.4. Go directly to the new manual page here

Help Index | Topics Index | Keywords Index | Full Index

© 2003-2018 GRASS Development Team, GRASS GIS 7.0.7svn Reference Manual