153GIS2 - 10. cvičení - GRASS GIS: Porovnání verzí

Z GeoWikiCZ
Řádek 34: Řádek 34:


<source lang="python">
<source lang="python">
import arcgisscripting, sys     #import modulu
import sys
gp = arcgisscripting.create()  #vytvoreni objektu geoprocessingu
from grass.script import core, vector as grass
gp.Overwriteoutput = 1          #nastaveno prepisovani
 
gp.workspace = "d:/jirka/skola/vyuka/gis/model/"    #nastaveni workspace - pracovni adresar nebo geodatabaze
input = sys.argv[1]    # String - nazev obce
try:
output = sys.argv[2]    # cesta k textovemu souboru
  input = sys.argv[1]    #String - nazev obce
 
  output = sys.argv[2]    #cesta k textovemu souboru
select = grass.vector_db_select(map = "obce",
  f = open(output, 'w')  #otevru file
                                where = "NAZEV = 'Liberec'")
  rows = gp.SearchCursor("obce.shp")   #vytvori cursor
 
  row = rows.next()       #promena row obsahuje jeden zaznam ze shapefilu
idx = select['columns'].index('OB01')
  while row:
ob01 = 0
      if row.GetValue("NAZEV") == input:
for record in select['values'].itervalues():
          pocet = row.GetValue("OB01")     #pocet obyvatel zadane obce
    ob01 += int(record[idx])
      row = rows.next()
 
          radky = gp.SearchCursor("obce.shp")
nazev_idx = select['columns'].index('NAZEV')
  rad = radky.next()
f = open(output, 'w')
  while rad:
try:
      if rad.GetValue("OB01") > pocet:
    for record in grass.vector_db_select(map = "obce",
          f.write(rad.GetValue("NAZEV")+" "+str(rad.GetValue("OB01"))+"\n")   #do souboru pisu obce ktere maji vic obyvatel nez zadana
                                        where = "OB01 > %d" % ob01)['values'].itervalues():
      rad = radky.next()
        f.write("%s%s\n" % (record[nazev_idx].ljust(15), record[idx]))
  f.close()
finally:
except:
    f.close()
  print gp.GetMessages()  
</source>
</source>


{{GIS}}
{{GIS}}
{{GFOSS}}
{{GFOSS}}
{{Python}}

Verze z 26. 5. 2009, 17:56

Stránka obsahuje ukázky skriptů v Pythonu pro GRASS GIS z 10. cvičení GIS2.

1

from grass.script import vector as grass

for nazev in grass.vector_columns(map = 'obce').keys():
    print nazev

2

from grass.script import core, vector as grass
 
select = grass.vector_db_select(map = "obce",
                                where = "NAZEV = 'Liberec'")

idx = select['columns'].index('OB01')
ob01 = 0
for record in select['values'].itervalues():
    ob01 += int(record[idx])

nazev_idx = select['columns'].index('NAZEV')
for record in grass.vector_db_select(map = "obce",
                                     where = "OB01 > %d" % ob01)['values'].itervalues():
    print unicode(record[nazev_idx], 'latin2').ljust(15), record[idx]

3

import sys
from grass.script import core, vector as grass

input = sys.argv[1]     # String - nazev obce
output = sys.argv[2]    # cesta k textovemu souboru

select = grass.vector_db_select(map = "obce",
                                where = "NAZEV = 'Liberec'")

idx = select['columns'].index('OB01')
ob01 = 0
for record in select['values'].itervalues():
    ob01 += int(record[idx])

nazev_idx = select['columns'].index('NAZEV')
f = open(output, 'w')
try:
    for record in grass.vector_db_select(map = "obce",
                                         where = "OB01 > %d" % ob01)['values'].itervalues():
        f.write("%s%s\n" % (record[nazev_idx].ljust(15), record[idx]))
finally:
    f.close()