construct_qgis_output_result_to_beter_format.R 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  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. #' @return A string.
  12. #' @seealso [qgisprocess::qgis_run_algorithm], [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. #' str <- "{ 'CREATEINDEX' : True, 'DATABASE' : 'Data', 'DROP_STRING_LENGTH' : False,
  21. #' 'ENCODING' : 'UTF-8', 'FORCE_SINGLEPART' : False, 'GEOMETRY_COLUMN' : 'geom',
  22. #' 'INPUT' : '/data/gpkg/teed/teed_l.gpkg|layername=teed_l', 'LOWERCASE_NAMES' : True,
  23. #' 'OVERWRITE' : True, 'PRIMARY_KEY' : 'fid', 'SCHEMA' : 'data', 'TABLENAME' : 'mikihiir' }"
  24. #'
  25. #' construct_qgis_output_result_to_beter_format(str = str)
  26. #' }
  27. construct_qgis_output_result_to_beter_format <- function(str = "") {
  28. ## Asendame "\'" sümbolitega "$$", et hilem tagasiasendust teha.
  29. str <- gsub("=\'([a-zA-Z0-9_/=./]*)\' ", "=@@\\1@@ ", str)
  30. str <- gsub("\\\"([a-zA-Z0-9_/=./]*)\\\"", "##\\1##", str)
  31. ## Asendame autentimise tunnuse salasõnaga.
  32. str <- gsub("(authcfg=[0-9a-zA-Z_/=.]+\\.{0,1}[0-9a-zA-Z_/=.]*)", "password=@@osm@@", str)
  33. str <- gsub("'True'", "1", str)
  34. str <- gsub("'False'", "0", str)
  35. # Numbrite ümbert ülakomade eemaldamine
  36. str <- gsub("'([0-9]+\\.{0,1}[0-9]*)'", "\\1", str)
  37. str <- gsub("[(]geom[)]", "(geom)", str)
  38. str_list <- str
  39. # Suurte tähtede ümbert ülakomade eemaldamine
  40. str <- gsub("'([A-Z_]*)'", "\\1", str)
  41. str <- gsub("[{]", "algorithm=algorithm,", str)
  42. str <- gsub("[}]", "", str)
  43. str <- gsub("##", "\"", str, fixed = T)
  44. str <- gsub("@@", "\\'", str, fixed = T)
  45. str <- gsub(", ", ",\n", str)
  46. str <- gsub(":", "=", str)
  47. # list
  48. str_list <- gsub("'", "\"", str_list)
  49. str_list <- gsub("@@", "\\", str_list)
  50. str_list <- gsub("##", "\\", str_list)
  51. str_list <- jsonlite::fromJSON(str_list)
  52. # names(str_list)
  53. cat(sprintf("\n\n%s\n\n\n",str))
  54. return(str_list)
  55. }