153GIS2 / 10. cvičení: Porovnání verzí

Z GeoWikiCZ
Řádek 100: Řádek 100:
       gp.Select_analysis(kraje, kraje_Select_shp, "\"NAZEV_ENG\" = '"+nazev+"'")
       gp.Select_analysis(kraje, kraje_Select_shp, "\"NAZEV_ENG\" = '"+nazev+"'")
       row = rows.next()
       row = rows.next()
</source>
==== 5 ====
<source lang="python">
import arcgisscripting, sys
gp = arcgisscripting.create()
gp.Overwriteoutput = 1
gp.workspace = "i:/pracovni/cajthaml/" 
try:
    input = sys.argv[1]
    mezi = sys.argv[2]
    dis = sys.argv[3]
    gp.Dissolve_management (input, mezi, dis)
    radky = gp.SearchCursor(mezi)
    rad = radky.next()
    while rad:
        nazev = rad.GetValue(dis)
        vystup = nazev+".shp"
        gp.Select_analysis (mezi, vystup, "\""+dis+"\" = '"+nazev+"'")
        rad = radky.next()
except:
  print gp.GetMessages()
</source>
</source>


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

Verze z 20. 4. 2010, 09:21

Hlavní stránka předmětuPředcházející cvičeníNásledující cvičení

Skriptování v Python - úvod

kniha o skriptování v ArcGIS

Data pro 4. skript

Ukázka skriptů

1

import arcgisscripting, sys     #import modulu
gp = arcgisscripting.create()   #vytvoreni objektu geoprocessingu
gp.Overwriteoutput = 1          #nastaveno prepisovani
gp.workspace = "d:/jirka/skola/vyuka/gis/model/"     #nastaveni workspace - pracovni adresar nebo geodatabaze
 
try:
   data = gp.Describe("obce.shp")   
   fields = data.Fields
   field = fields.next()
   while field:
      print field.Name
      field = fields.next()
except:
   print gp.GetMessages()

2

import arcgisscripting, sys     #import modulu
gp = arcgisscripting.create()   #vytvoreni objektu geoprocessingu
gp.Overwriteoutput = 1          #nastaveno prepisovani
gp.workspace = "d:/jirka/skola/vyuka/gis/model/"     #nastaveni workspace - pracovni adresar nebo geodatabaze
 
try:
  input = "Liberec"     #String - nazev obce
  rows = gp.SearchCursor("obce.shp")   #vytvori cursor
  row = rows.next()       #promena row obsahuje jeden zaznam ze shapefilu
  while row:
      if row.GetValue("NAZEV") == input:
          pocet = row.GetValue("OB01")     #pocet obyvatel zadane obce
      row = rows.next()
  radky = gp.SearchCursor("obce.shp")
  rad = radky.next()
  while rad:
      if rad.GetValue("OB01") > pocet:
         print rad.GetValue("NAZEV"), rad.GetValue("OB01")
      rad = radky.next()
except:
  print gp.GetMessages()

3

import arcgisscripting, sys     #import modulu
gp = arcgisscripting.create()   #vytvoreni objektu geoprocessingu
gp.Overwriteoutput = 1          #nastaveno prepisovani
gp.workspace = "d:/jirka/skola/vyuka/gis/model/"     #nastaveni workspace - pracovni adresar nebo geodatabaze
try:
  input = sys.argv[1]     #String - nazev obce
  output = sys.argv[2]    #cesta k textovemu souboru
  f = open(output, 'w')   #otevru file
  rows = gp.SearchCursor("obce.shp")   #vytvori cursor
  row = rows.next()       #promena row obsahuje jeden zaznam ze shapefilu
  while row:
      if row.GetValue("NAZEV") == input:
          pocet = row.GetValue("OB01")     #pocet obyvatel zadane obce
      row = rows.next()
  radky = gp.SearchCursor("obce.shp")
  rad = radky.next()
  while rad:
      if rad.GetValue("OB01") > pocet:
          f.write(rad.GetValue("NAZEV")+" "+str(rad.GetValue("OB01"))+"\n")    #do souboru pisu obce ktere maji vic obyvatel nez zadana
      rad = radky.next()
  f.close()
except:
  print gp.GetMessages()


4

import sys, string, os, arcgisscripting

gp = arcgisscripting.create()
gp.workspace = "d:/jirka/skola/vyuka/gis/"     

kraje = "D:\\jirka\\skola\\vyuka\\gis\\kraje.shp"

rows = gp.SearchCursor("kraje.shp")   #vytvori cursor
row = rows.next()       #promena row obsahuje jeden zaznam ze shapefilu
while row:
      nazev = row.GetValue("NAZEV_ENG") 
      kraje_Select_shp = "D:\\jirka\\skola\\vyuka\\gis\\"+nazev+".shp"
      gp.Select_analysis(kraje, kraje_Select_shp, "\"NAZEV_ENG\" = '"+nazev+"'")
      row = rows.next()

5

import arcgisscripting, sys
gp = arcgisscripting.create()
gp.Overwriteoutput = 1 
gp.workspace = "i:/pracovni/cajthaml/"  

try:
    input = sys.argv[1] 
    mezi = sys.argv[2]
    dis = sys.argv[3]

    gp.Dissolve_management (input, mezi, dis) 

    radky = gp.SearchCursor(mezi)
    rad = radky.next()

    while rad:
        nazev = rad.GetValue(dis)
        vystup = nazev+".shp"
        gp.Select_analysis (mezi, vystup, "\""+dis+"\" = '"+nazev+"'")
        rad = radky.next()

except:
  print gp.GetMessages()