W pewnym sensie utknąłem, próbując znaleźć sposób uruchomienia sextante z samodzielnego pytona z dystrybucji OSGeo4W. Powodem, dla którego chcę to zrobić, jest zmęczenie wprowadzaniem parametrów w oknie dialogowym za każdym razem, gdy chcę przetestować model z Model Builder.
Więc oto skrypt w języku Python nazwijmy go test.py
# as per http://qgis.org/pyqgis-cookbook/intro.html#using-pyqgis-in-custom-application
from qgis.core import *
# supply path to where is your qgis installed
QgsApplication.setPrefixPath("C:/OSGeo4W/apps/qgis", True)
# load providers
QgsApplication.initQgis()
from sextante.core.Sextante import Sextante
Sextante.alglist()
Sextante.alghelp("saga:slopeaspectcurvature")
Dzwonię z mojego pliku wsadowego
@echo off
set OSGEO4W_ROOT=C:\OSGeo4W
set PYTHONPATH=%OSGEO4W_ROOT%\apps\qgis\python;%OSGEO4W_ROOT%\apps\qgis\python\plugins;%HOME%/.qgis/python/plugins
set PATH=%OSGEO4W_ROOT%\bin;%OSGEO4W_ROOT%\apps\qgis\bin;%OSGEO4W_ROOT%\apps\qgis\plugins
python test.py
Problem polega na tym, że mówi, Algorithm not found
podczas gdy otrzymuję znaczące dane wyjściowe z konsoli python QGIS.
Czuję, że brakuje mi czegoś inicjującego. Ale co?
Czy jest lepszy sposób na przetestowanie modelu niż wprowadzenie ton parametrów za pomocą GUI?
AKTUALIZACJA 7/2/2012
Szukam ogólnego rozwiązania pythonowego do testowania przy użyciu algorytmów „moje”. Wspomniany algorytm jest tylko przykładem pokazującym, że coś prawdopodobnie nie zostało zainicjowane.
AKTUALIZACJA 7/27/2012
Alternatywą dla Script Runner jest użycie konsoli IPython do debugowania skryptów. Poza tym nie wydaje się, aby można było przeprowadzać proste testy jednostkowe przy użyciu sextante bez niczego innego :(
AKTUALIZACJA 7/30/2012
Jak sugeruje Victor Olaya, staram się zainicjować Sextante jak w poniższym kodzie.
#!/usr/bin/env python
import sys
from PyQt4.QtGui import QApplication
from sextante.core.Sextante import Sextante
def main():
""" main function or something """
# as per http://qgis.org/pyqgis-cookbook/intro.html#using-pyqgis-in-custom-application
from qgis.core import *
import qgis.utils
app = QApplication(sys.argv)
# supply path to where is your qgis installed
QgsApplication.setPrefixPath("C:/OSGeo4W/apps/qgis", True)
# load providers
QgsApplication.initQgis()
# how???
# qgis.utils.iface = QgisInterface.instance()
Sextante.initialize()
run_script(qgis.utils.iface)
def run_script(iface):
""" this shall be called from Script Runner"""
Sextante.alglist()
Sextante.alghelp("saga:slopeaspectcurvature")
if __name__=="__main__":
main()
Jednak dostaję coś takiego
Traceback (most recent call last):
File "test.py", line 29, in
main()
File "test.py", line 20, in main
Sextante.initialize()
File "C:\Documents and Settings\user\.qgis\python\plugins\sextante\core\Sextante.py", line 94, in initialize
Sextante.addProvider(GrassAlgorithmProvider())
File "C:\Documents and Settings\user\.qgis\python\plugins\sextante\grass\GrassAlgorithmProvider.py", lin
e 17, in __init__
self.actions.append(DefineGrassRegionAction())
File "C:\Documents and Settings\user\.qgis\python\plugins\sextante\grass\DefineGrassRegionAction.py", li
ne 16, in __init__
canvas = QGisLayers.iface.mapCanvas()
AttributeError: 'NoneType' object has no attribute 'mapCanvas'
Cóż ... to wszystko staje się dyskusją na liście mailowej. Być może warto przejść do qgis-user lub qgis-developer zamiast SE.
iface
w samodzielnym skrypcie QGIS.iface
jest użyteczny tylko podczas pracy w bocznym QGIS.