construct_qgis_output_result_to_better_format.R 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #' QGIS-i funktsiooni väljundist uue sisendiks vajaliku fraasi konstrueerimine
  2. #'
  3. #' See funktsioon konstrueerib 'QGIS' funktsiooni väljundi logisse tekkiva input parameetrid kujule, mida oleks võimalik kasutada funktsiooni \code{\link[qgisprocess]{qgis_run_algorithm}} argumentidena.
  4. #'
  5. #' Näidis:
  6. #' Processing algorithm…
  7. #' Algorithm 'Export to PostgreSQL' starting…
  8. #' Input parameters:
  9. #' { 'CREATEINDEX' : True, 'DATABASE' : 'Data', 'DROP_STRING_LENGTH' : False, 'ENCODING' : 'UTF-8', 'FORCE_SINGLEPART' : False, 'GEOMETRY_COLUMN' : 'geom', 'INPUT' : '/data/gpkg/teed/teed_l.gpkg|layername=teed_l', 'LOWERCASE_NAMES' : True, 'OVERWRITE' : True, 'PRIMARY_KEY' : 'fid', 'SCHEMA' : 'data', 'TABLENAME' : 'mikihiir' }
  10. #' @param str string A QGIS input parameters.
  11. #' @param algorithm string A QGIS algorithm.
  12. #' @return A string.[ruut::construct_ogr2ogr_PG_connect_str]
  13. #' @keywords QGIS
  14. #' @export
  15. #' @examples
  16. #'
  17. #' \dontrun{
  18. #'
  19. #' # QGIS funktsiooni käivitamisel saatakse logisse argumentidest järgmine väljund
  20. #' ## Demo
  21. #' # Algorithm 'Buffer' starting…
  22. #' system(sprintf("qgis_process list | grep %s", 'Buffer'))
  23. #' algorithm <- "native:buffer"
  24. #'
  25. #' str <- "{ 'DISSOLVE' : False, 'DISTANCE' : 100, 'END_CAP_STYLE' : 2,
  26. #' 'INPUT' : '/data/gpkg/artiklid/artikkel_210127_valga_matsalu_lahemaa/matsalu.gpkg|layername=bb',
  27. #' 'JOIN_STYLE' : 1, 'MITER_LIMIT' : 2,
  28. #' 'OUTPUT' : 'postgres://dbname=\'data\' host=localhost port=6432 user=\'osm\' password=\'osm\'
  29. #' sslmode=disable table=\"data\".\"test22\" (geom)', 'SEGMENTS' : 5 }"
  30. #'
  31. #' cmd <- ruut::construct_qgis_output_result_to_better_format(str = str, algorithm = algorithm)
  32. #' system(cmd)
  33. #'
  34. #' }
  35. construct_qgis_output_result_to_better_format <- function(str = "", algorithm = "xxxxxxxxxx") {
  36. # Eemaldame reavahed
  37. str <- gsub("\n", " ", str)
  38. # Tühjal stringil vahetame kõrvutiolevad 1-kordsed jutumärgid 2-kordsetega
  39. str <- gsub("''", "\"\"", str)
  40. # Suurte tähtede ümbert ülakomade eemaldamine
  41. str <- gsub("'([A-Z_]*)'", "--\\1", str)
  42. # Väärtustel vahetame väärtuste välimised 1-kordsed jutumärgid 2-kordsetega
  43. str <- gsub(" : ", "=", str)
  44. # Loogiliste sulgude eemaldamine
  45. str <- gsub("[{]", "qgis_process run algorithm ", str)
  46. str <- gsub("[}]", "", str)
  47. # Eemaldame komad
  48. str <- gsub(", ", " ", str)
  49. ## Asendame autentimise tunnuse salasõnaga.
  50. str <- gsub("(authcfg=[0-9a-zA-Z_/=.]+\\.{0,1}[0-9a-zA-Z_/=.]*)", "password='osm'", str)
  51. # Asendame algoritmi
  52. str <- gsub("algorithm", algorithm, str)
  53. # Nurksulgude asendamine
  54. str <- gsub("[[]", "", str)
  55. str <- gsub("[]]", "", str)
  56. # EPSG: kandiliste sulgude lisamine tagasi
  57. str <- gsub("(EPSG:[0-9]+\\.{0,1}[0-9]*)", "[\\1]", str)
  58. cat(str)
  59. str
  60. }