Beberapa bahasa skrip geospasial:
1) Python / Jython
Python / Jython saja:
Python dan Jython dapat digunakan sendiri untuk memproses data geospasial tanpa perangkat lunak apa pun, menggunakan modul seperti osgeo (GDAL / OGR), PySAL, Shapely, Fiona, Pyshp, ..., lihat Indeks Paket Python, Topik: GIS atau Geoscript (Jython) . Ada banyak contoh di GST
sebagai bahasa scripting dalam aplikasi
QGIS, GRASS GIS, GvSIG, OpenJump atau Geoserver (dan ArcGIS, lihat di atas) menggunakan Python / Jython untuk skrip:
- GIS Quantum ( Python , 1.8, perubahan dalam versi master)
from qgis.core import *
layer = qgis.utils.iface.activeLayer()
for elem in layer.selectedFeatures():
geom= elem.geometry()
attrs = elem.attributeMap()
from grass.script import raster as grassr
grassr.raster_info('s_newfrst3@moi')
{'north':118869.900569, 'timestamp': '"none"', 'min': -456.08587646484398,
'datatype': 'FCELL', 'max': 265.500732421875, 'ewres':
14.008076920000001, 'vertical_datum': '', 'west': 164160.653425,
'units': '', 'title': ' (s_newfrst3)', 'east': 176641.849961, 'nsres':
13.976472729999999, 'south': 112552.534895}
from gvsig import *
layer = currentLayer()
features = layer.features()
for feature in features:
geom = feature.geometry()
values = feature.getValues()
from org.openjump.util.python.JUMP_GIS_Framework import *
layer = getSelectedLayers()
for i in layer.iterator():
print layer.name
# first element of the layer
fc = layer[0].featureCollectionWrapper
for elem in range(fc.size):
obj = fc.features[elem]
geom = obj.getGeometry()
from geoserver import Catalog
cat = Catalog('aff_geol')
print cat.stores()
[u'affleurements', u'cartes']
st = cat['affleurements']
print st.layers()
[u'affs']
l = st['affs']
print l.count()
3214
print l.bounds()
(107206.74,148102.45,114110.46,157514.40, EPSG:31370)
dan Anda juga dapat menggunakan perpustakaan Java lainnya seperti Java Topology Suite ( Jython ):
import sys
sys.path.append('.../jts-1.8.0/lib/jts-1.8.jar')
from com.vividsolutions.jts.geom import Point
2) Bash
GRASS GIS menggunakan Bash (shell and scripts (.sh))
GRASS 6.4.2 (geol):~ > v.out.ascii in=ligneprofil format=standard | grep '^ '|\r.profile -c in=MNT res=30 output=profil.pts
3) R (tidak ada bahasa kode prettify)
Anda dapat menggunakan R untuk semua perawatan geospasial, lihat Tampilan Tugas CRAN: Analisis Data Spasial :
library(maptools)
geol <-readShapePoly("cal.shp")
library(rgdal)
geol = readOGR(dsn=".", layer="cal")
library(PBSmapping)
geol = importShapefile("cal.shp")
library(shapefiles)
geol <- read.shapefile("cal")
# PostGIS
geol = readOGR("PG:dbname=test", "cal")
tetapi GRASS GIS juga dapat menggunakan R secara langsung:
GRASS 6.4.2 (geol):~ > R
R version ....
> library(spgrass6)
> G <- gmeta6() # paramètres de Grass, région etc.
> montrait <- readRAST6(c("geologie", "mnt"),cat=c(TRUE, FALSE), ignore.stderr=TRUE,plugin=NULL)
4) BeanShell (Jawa)
OpenJump juga dapat menggunakan Beanshell (konsol atau skrip)
layer = wc.layerManager .getLayer("road").featureCollectionWrapper;
getLongest() {
max = -1;
for (f : layer.features) { length = f.geometry.length; if (f.geometry.length > max) {max = length; result = f;}
}
return result;
print(getLongest().ID);
5) Groovy (Java), Scala dan JavaScript
Anda dapat menggunakan bahasa tesis ini dengan GeoScript, lihat contoh
6) Bahasa Query JEQL
Seperti yang ditunjukkan oleh Martin Davis ( label jeql )
shapefileReader t file: "agder/agder_buffer.shp";
t = select geomUnionMem(GEOMETRY) g from t;
ShapefileWriter t file: "result.shp";