v.in.gns.py 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. #!/usr/bin/env python
  2. ############################################################################
  3. #
  4. # MODULE: v.in.gns
  5. #
  6. # AUTHOR(S): Markus Neteler, neteler itc it
  7. # Converted to Python by Glynn Clements
  8. #
  9. # PURPOSE: Import GEOnet Names Server (GNS) country files into a GRASS vector map
  10. # http://earth-info.nga.mil/gns/html/
  11. # -> Download Names Files for Countries and Territories (FTP)
  12. #
  13. # Column names: http://earth-info.nga.mil/gns/html/help.htm
  14. #
  15. # COPYRIGHT: (c) 2005 GRASS Development Team
  16. #
  17. # This program is free software under the GNU General Public
  18. # License (>=v2). Read the file COPYING that comes with GRASS
  19. # for details.
  20. #
  21. # TODO: - see below in the code
  22. # - add extra columns explaining some column acronyms,
  23. # e.g. FC (Feature Classification)
  24. #############################################################################
  25. #%module
  26. #% description: Imports US-NGA GEOnet Names Server (GNS) country files into a GRASS vector points map.
  27. #% keywords: vector
  28. #% keywords: import
  29. #% keywords: gazetteer
  30. #%end
  31. #%option G_OPT_F_INPUT
  32. #% description: Name of input uncompressed GNS file from NGA (with .txt extension)
  33. #%end
  34. #%option G_OPT_V_OUTPUT
  35. #% required: no
  36. #%end
  37. import sys
  38. import os
  39. from grass.script.utils import try_remove, basename, parse_key_val
  40. from grass.script import core as grass
  41. from grass.script import vector as vgrass
  42. def main():
  43. fileorig = options['input']
  44. filevect = options['output']
  45. if not filevect:
  46. filevect = basename(fileorig, 'txt')
  47. #are we in LatLong location?
  48. s = grass.read_command("g.proj", flags='j')
  49. kv = parse_key_val(s)
  50. if kv['+proj'] != 'longlat':
  51. grass.fatal(_("This module only operates in LatLong/WGS84 locations"))
  52. #### setup temporary file
  53. tmpfile = grass.tempfile()
  54. coldescs = [("RC", "rc integer"),
  55. ("UFI", "uf1 integer"),
  56. ("UNI", "uni integer"),
  57. ("LAT", "lat double precision"),
  58. ("LONG", "lon double precision"),
  59. ("DMS_LAT", "dms_lat varchar(6)"),
  60. ("DMS_LONG", "dms_long varchar(7)"),
  61. ("UTM", "utm varchar(4)"),
  62. ("JOG", "jog varchar(7)"),
  63. ("FC", "fc varchar(1)"),
  64. ("DSG", "dsg varchar(5)"),
  65. ("PC", "pc integer"),
  66. ("CC1", "cci varchar(2)"),
  67. ("ADM1", "adm1 varchar(2)"),
  68. ("ADM2", "adm2 varchar(200)"),
  69. ("DIM", "dim integer"),
  70. ("CC2", "cc2 varchar(2)"),
  71. ("NT", "nt varchar(1)"),
  72. ("LC", "lc varchar(3)"),
  73. ("SHORT_FORM", "shortform varchar(128)"),
  74. ("GENERIC", "generic varchar(128)"),
  75. ("SORT_NAME", "sortname varchar(200)"),
  76. ("FULL_NAME", "fullname varchar(200)"),
  77. ("FULL_NAME_ND","funamesd varchar(200)"),
  78. ("MODIFY_DATE", "mod_date date")]
  79. colnames = [desc[0] for desc in coldescs]
  80. coltypes = dict([(desc[0], 'integer' in desc[1]) for desc in coldescs])
  81. header = None
  82. num_places = 0
  83. inf = file(fileorig)
  84. outf = file(tmpfile, 'wb')
  85. for line in inf:
  86. fields = line.rstrip('\r\n').split('\t')
  87. if not header:
  88. header = fields
  89. continue
  90. vars = dict(zip(header, fields))
  91. fields2 = []
  92. for col in colnames:
  93. if col in vars:
  94. if coltypes[col] and vars[col] == '':
  95. fields2.append('0')
  96. else:
  97. fields2.append(vars[col])
  98. else:
  99. if coltypes[col]:
  100. fields2.append('0')
  101. else:
  102. fields2.append('')
  103. line2 = ';'.join(fields2) + '\n'
  104. outf.write(line2)
  105. num_places += 1
  106. outf.close()
  107. inf.close()
  108. grass.message(_("Converted %d place names.") % num_places)
  109. #TODO: fix dms_lat,dms_long DDMMSS -> DD:MM:SS
  110. # Solution:
  111. # IN=DDMMSS
  112. # DEG=`echo $IN | cut -b1,2`
  113. # MIN=`echo $IN | cut -b3,4`
  114. # SEC=`echo $IN | cut -b5,6`
  115. # DEG_STR="$DEG:$MIN:$SEC"
  116. #modifications (to match DBF 10 char column name limit):
  117. # short_form -> shortform
  118. # sort_name -> sortname
  119. # full_name -> fullname
  120. # full_name_sd -> funamesd
  121. # pump data into GRASS:
  122. columns = [desc[1] for desc in coldescs]
  123. grass.run_command('v.in.ascii', cat = 0, x = 5, y = 4, sep = ';',
  124. input = tmpfile, output = filevect,
  125. columns = columns)
  126. try_remove(tmpfile)
  127. # write cmd history:
  128. vgrass.vector_history(filevect)
  129. if __name__ == "__main__":
  130. options, flags = grass.parser()
  131. main()