Browse Source

提取矢量图斑生成图片

gushoubang 5 months ago
commit
b1496e8e43
100 changed files with 74 additions and 0 deletions
  1. BIN
      __pycache__/db_util.cpython-310.pyc
  2. BIN
      __pycache__/file_util.cpython-310.pyc
  3. BIN
      __pycache__/img_util.cpython-310.pyc
  4. 41 0
      db_util.py
  5. 33 0
      file_util.py
  6. BIN
      img/DDOM/6401812024070108270001DDOM.tif
  7. BIN
      img/DDOM/6401812024070108270002DDOM.tif
  8. BIN
      img/DDOM/6401812024070108270003DDOM.tif
  9. BIN
      img/DDOM/6401812024070108270004DDOM.tif
  10. BIN
      img/DDOM/6401812024070108270005DDOM.tif
  11. BIN
      img/DDOM/6401812024070108270006DDOM.tif
  12. BIN
      img/DDOM/6401812024070108270007DDOM.tif
  13. BIN
      img/DDOM/6401812024070108270008DDOM.tif
  14. BIN
      img/DDOM/6401812024070108270009DDOM.tif
  15. BIN
      img/DDOM/6401812024070108270010DDOM.tif
  16. BIN
      img/DDOM/6401812024070108270011DDOM.tif
  17. BIN
      img/DDOM/6401812024070108270014DDOM.tif
  18. BIN
      img/DDOM/6401812024070108270015DDOM.tif
  19. BIN
      img/DDOM/6401812024070108270020DDOM.tif
  20. BIN
      img/DDOM/6401812024070108270023DDOM.tif
  21. BIN
      img/DDOM/6401812024070108270057DDOM.tif
  22. BIN
      img/DDOM/6401812024070108270318DDOM.tif
  23. BIN
      img/DDOM/6401812024070108270319DDOM.tif
  24. BIN
      img/DDOM/6401812024070108270320DDOM.tif
  25. BIN
      img/DDOM/6401812024070108270321DDOM.tif
  26. BIN
      img/DDOM/6401812024070108270322DDOM.tif
  27. BIN
      img/DDOM/6401812024070108270325DDOM.tif
  28. BIN
      img/DDOM/6401812024070108270326DDOM.tif
  29. BIN
      img/DDOM/6401812024070108270338DDOM.tif
  30. BIN
      img/DDOM/6401812024070108270339DDOM.tif
  31. BIN
      img/DDOM/6401812024070108270340DDOM.tif
  32. BIN
      img/DDOM/6401812024070108270341DDOM.tif
  33. BIN
      img/DDOM/6401812024070108270342DDOM.tif
  34. BIN
      img/DDOM/6401812024070108270343DDOM.tif
  35. BIN
      img/DDOM/6401812024070108270344DDOM.tif
  36. BIN
      img/DDOM/6401812024070108270345DDOM.tif
  37. BIN
      img/DDOM/6401812024070108270346DDOM.tif
  38. BIN
      img/DDOM/6401812024070108270347DDOM.tif
  39. BIN
      img/DDOM/6401812024070108270348DDOM.tif
  40. BIN
      img/DDOM/6401812024070108270349DDOM.tif
  41. BIN
      img/DDOM/6401812024070108270350DDOM.tif
  42. BIN
      img/DDOM/6401812024070108270351DDOM.tif
  43. BIN
      img/DDOM/6401812024070108270352DDOM.tif
  44. BIN
      img/DDOM/6401812024070108270353DDOM.tif
  45. BIN
      img/DDOM/6401812024070108270354DDOM.tif
  46. BIN
      img/DDOM/6401812024070108270355DDOM.tif
  47. BIN
      img/DDOM/6401812024070108270356DDOM.tif
  48. BIN
      img/DDOM/6401812024070108270357DDOM.tif
  49. BIN
      img/DDOM/6401812024070108270358DDOM.tif
  50. BIN
      img/DDOM/6401812024070108270359DDOM.tif
  51. BIN
      img/DDOM/6401812024070108270360DDOM.tif
  52. BIN
      img/DDOM/6401812024070108270361DDOM.tif
  53. BIN
      img/DDOM/6401812024070108270362DDOM.tif
  54. BIN
      img/DDOM/6401812024070108270363DDOM.tif
  55. BIN
      img/DDOM/6401812024070108270364DDOM.tif
  56. BIN
      img/DDOM/6401812024070108270365DDOM.tif
  57. BIN
      img/DDOM/6401812024070108270366DDOM.tif
  58. BIN
      img/DDOM/6401812024070108270367DDOM.tif
  59. BIN
      img/DDOM/6401812024070108270368DDOM.tif
  60. BIN
      img/DDOM/6401812024070108270369DDOM.tif
  61. BIN
      img/DDOM/6401812024070108270370DDOM.tif
  62. BIN
      img/DDOM/6401812024070108270371DDOM.tif
  63. BIN
      img/DDOM/6401812024070108270372DDOM.tif
  64. BIN
      img/DDOM/6401812024070108270373DDOM.tif
  65. BIN
      img/DDOM/6401812024070108270374DDOM.tif
  66. BIN
      img/DDOM/6401812024070108270375DDOM.tif
  67. BIN
      img/DDOM/6401812024070108270376DDOM.tif
  68. BIN
      img/DDOM/6401812024070108270377DDOM.tif
  69. BIN
      img/DDOM/6401812024070108270378DDOM.tif
  70. BIN
      img/DDOM/6401812024070108270379DDOM.tif
  71. BIN
      img/DDOM/6401812024070108270380DDOM.tif
  72. BIN
      img/DDOM/6401812024070108270381DDOM.tif
  73. BIN
      img/DDOM/6401812024070108270382DDOM.tif
  74. BIN
      img/DDOM/6401812024070108270383DDOM.tif
  75. BIN
      img/DDOM/6401812024070108270384DDOM.tif
  76. BIN
      img/DDOM/6401812024070108270385DDOM.tif
  77. BIN
      img/DDOM/6401812024070108270386DDOM.tif
  78. BIN
      img/DDOM/6401812024070108270387DDOM.tif
  79. BIN
      img/DDOM/6401812024070108270388DDOM.tif
  80. BIN
      img/DDOM/6401812024070108270389DDOM.tif
  81. BIN
      img/DDOM/6401812024070108270390DDOM.tif
  82. BIN
      img/DDOM/6401812024070108270391DDOM.tif
  83. BIN
      img/DDOM/6401812024070108270392DDOM.tif
  84. BIN
      img/DDOM/6401812024070108270393DDOM.tif
  85. BIN
      img/DDOM/6401812024070108270394DDOM.tif
  86. BIN
      img/DDOM/6401812024070108270395DDOM.tif
  87. BIN
      img/DDOM/6401812024070108270396DDOM.tif
  88. BIN
      img/DDOM/6401812024070108270397DDOM.tif
  89. BIN
      img/DDOM/6401812024070108270398DDOM.tif
  90. BIN
      img/DDOM/6401812024070108270399DDOM.tif
  91. BIN
      img/DDOM/6401812024070108270400DDOM.tif
  92. BIN
      img/DDOM/6401812024070108270401DDOM.tif
  93. BIN
      img/DDOM/6401812024070108270402DDOM.tif
  94. BIN
      img/DDOM/6401812024070108270403DDOM.tif
  95. BIN
      img/DDOM/6401812024070108270404DDOM.tif
  96. BIN
      img/DDOM/6401812024070108270405DDOM.tif
  97. BIN
      img/DDOM/6401812024070108270406DDOM.tif
  98. BIN
      img/DDOM/6401812024070108270407DDOM.tif
  99. BIN
      img/DDOM/6401812024070108270408DDOM.tif
  100. BIN
      img/DDOM/6401812024070108270409DDOM.tif

BIN
__pycache__/db_util.cpython-310.pyc


BIN
__pycache__/file_util.cpython-310.pyc


BIN
__pycache__/img_util.cpython-310.pyc


+ 41 - 0
db_util.py

@@ -0,0 +1,41 @@
+# 连接数据库
+import psycopg2
+from psycopg2.extras import DictCursor
+import logging
+
+# 配置日志
+logging.basicConfig(level=logging.INFO)
+logger = logging.getLogger(__name__)
+
+
+conn = psycopg2.connect(
+    dbname="test",
+    user="postgres",
+    password="postgis",
+    host="192.168.100.30",
+    port="5432"
+)
+
+
+def getDiffEwkt(code, ewkt):
+    with conn.cursor(cursor_factory=DictCursor) as cur:
+        # sql = """ SELECT
+        #                 st_asewkt ( st_difference ( st_geomfromewkt ( %s ), tb.geom ) )
+        #             FROM
+        #                 tb
+        #             WHERE
+        #                 tb."编号" = %s;"""
+        sql="""SELECT
+	st_asewkt ( st_difference ( st_geomfromewkt ( %s ), st_union ( tb.geom ) ) )
+FROM
+	tb
+WHERE
+	st_contains ( st_geomfromewkt ( %s ), tb.geom );"""
+        # complete_sql = cur.mogrify(sql, (ewkt,ewkt,)).decode('utf-8')
+        # logger.info(f"Executing SQL: {complete_sql}")
+        cur.execute(sql, (ewkt,ewkt,))
+        res = cur.fetchone()
+    return res[0]
+# ewkt='SRID=4490;POLYGON ((106.67844989540063 38.207187208754306, 106.67844989540063 38.212680372816806, 106.67295673133813 38.212680372816806, 106.67295673133813 38.207187208754306, 106.67844989540063 38.207187208754306))'
+# getEwkt=getDiffEwkt('6401812024070108270001',ewkt)
+# print(getEwkt)

+ 33 - 0
file_util.py

@@ -0,0 +1,33 @@
+import os
+import rasterio
+from shapely.geometry import box
+
+
+def getAllFiles(filePath):
+    fileList = []
+
+    # 设置要遍历的文件夹路径
+    folder_path = os.path.join(os.path.dirname(__file__), filePath)
+
+    # 遍历文件夹
+    for root, dirs, files in os.walk(folder_path):
+        for file in files:
+            file_path = os.path.join(root, file)
+            fileList.append(file_path)
+    return fileList
+
+# allPath = getAllFiles('img/DDOM')
+
+
+def getTifEwkt(filePath):
+    # 读取 tif 文件
+    with rasterio.open(filePath) as src:
+        # 获取 tif 文件的边界框 (bounds)
+        bounds = src.bounds
+        # 使用 shapely 的 box 函数创建矩形几何对象
+        bbox = box(bounds.left, bounds.bottom, bounds.right, bounds.top)
+        # 将矩形几何对象转换为 WKT 格式
+        wkt = bbox.wkt
+        ewkt='SRID=4490;'+wkt
+        print('矢量范围:'+wkt)
+        return ewkt

BIN
img/DDOM/6401812024070108270001DDOM.tif


BIN
img/DDOM/6401812024070108270002DDOM.tif


BIN
img/DDOM/6401812024070108270003DDOM.tif


BIN
img/DDOM/6401812024070108270004DDOM.tif


BIN
img/DDOM/6401812024070108270005DDOM.tif


BIN
img/DDOM/6401812024070108270006DDOM.tif


BIN
img/DDOM/6401812024070108270007DDOM.tif


BIN
img/DDOM/6401812024070108270008DDOM.tif


BIN
img/DDOM/6401812024070108270009DDOM.tif


BIN
img/DDOM/6401812024070108270010DDOM.tif


BIN
img/DDOM/6401812024070108270011DDOM.tif


BIN
img/DDOM/6401812024070108270014DDOM.tif


BIN
img/DDOM/6401812024070108270015DDOM.tif


BIN
img/DDOM/6401812024070108270020DDOM.tif


BIN
img/DDOM/6401812024070108270023DDOM.tif


BIN
img/DDOM/6401812024070108270057DDOM.tif


BIN
img/DDOM/6401812024070108270318DDOM.tif


BIN
img/DDOM/6401812024070108270319DDOM.tif


BIN
img/DDOM/6401812024070108270320DDOM.tif


BIN
img/DDOM/6401812024070108270321DDOM.tif


BIN
img/DDOM/6401812024070108270322DDOM.tif


BIN
img/DDOM/6401812024070108270325DDOM.tif


BIN
img/DDOM/6401812024070108270326DDOM.tif


BIN
img/DDOM/6401812024070108270338DDOM.tif


BIN
img/DDOM/6401812024070108270339DDOM.tif


BIN
img/DDOM/6401812024070108270340DDOM.tif


BIN
img/DDOM/6401812024070108270341DDOM.tif


BIN
img/DDOM/6401812024070108270342DDOM.tif


BIN
img/DDOM/6401812024070108270343DDOM.tif


BIN
img/DDOM/6401812024070108270344DDOM.tif


BIN
img/DDOM/6401812024070108270345DDOM.tif


BIN
img/DDOM/6401812024070108270346DDOM.tif


BIN
img/DDOM/6401812024070108270347DDOM.tif


BIN
img/DDOM/6401812024070108270348DDOM.tif


BIN
img/DDOM/6401812024070108270349DDOM.tif


BIN
img/DDOM/6401812024070108270350DDOM.tif


BIN
img/DDOM/6401812024070108270351DDOM.tif


BIN
img/DDOM/6401812024070108270352DDOM.tif


BIN
img/DDOM/6401812024070108270353DDOM.tif


BIN
img/DDOM/6401812024070108270354DDOM.tif


BIN
img/DDOM/6401812024070108270355DDOM.tif


BIN
img/DDOM/6401812024070108270356DDOM.tif


BIN
img/DDOM/6401812024070108270357DDOM.tif


BIN
img/DDOM/6401812024070108270358DDOM.tif


BIN
img/DDOM/6401812024070108270359DDOM.tif


BIN
img/DDOM/6401812024070108270360DDOM.tif


BIN
img/DDOM/6401812024070108270361DDOM.tif


BIN
img/DDOM/6401812024070108270362DDOM.tif


BIN
img/DDOM/6401812024070108270363DDOM.tif


BIN
img/DDOM/6401812024070108270364DDOM.tif


BIN
img/DDOM/6401812024070108270365DDOM.tif


BIN
img/DDOM/6401812024070108270366DDOM.tif


BIN
img/DDOM/6401812024070108270367DDOM.tif


BIN
img/DDOM/6401812024070108270368DDOM.tif


BIN
img/DDOM/6401812024070108270369DDOM.tif


BIN
img/DDOM/6401812024070108270370DDOM.tif


BIN
img/DDOM/6401812024070108270371DDOM.tif


BIN
img/DDOM/6401812024070108270372DDOM.tif


BIN
img/DDOM/6401812024070108270373DDOM.tif


BIN
img/DDOM/6401812024070108270374DDOM.tif


BIN
img/DDOM/6401812024070108270375DDOM.tif


BIN
img/DDOM/6401812024070108270376DDOM.tif


BIN
img/DDOM/6401812024070108270377DDOM.tif


BIN
img/DDOM/6401812024070108270378DDOM.tif


BIN
img/DDOM/6401812024070108270379DDOM.tif


BIN
img/DDOM/6401812024070108270380DDOM.tif


BIN
img/DDOM/6401812024070108270381DDOM.tif


BIN
img/DDOM/6401812024070108270382DDOM.tif


BIN
img/DDOM/6401812024070108270383DDOM.tif


BIN
img/DDOM/6401812024070108270384DDOM.tif


BIN
img/DDOM/6401812024070108270385DDOM.tif


BIN
img/DDOM/6401812024070108270386DDOM.tif


BIN
img/DDOM/6401812024070108270387DDOM.tif


BIN
img/DDOM/6401812024070108270388DDOM.tif


BIN
img/DDOM/6401812024070108270389DDOM.tif


BIN
img/DDOM/6401812024070108270390DDOM.tif


BIN
img/DDOM/6401812024070108270391DDOM.tif


BIN
img/DDOM/6401812024070108270392DDOM.tif


BIN
img/DDOM/6401812024070108270393DDOM.tif


BIN
img/DDOM/6401812024070108270394DDOM.tif


BIN
img/DDOM/6401812024070108270395DDOM.tif


BIN
img/DDOM/6401812024070108270396DDOM.tif


BIN
img/DDOM/6401812024070108270397DDOM.tif


BIN
img/DDOM/6401812024070108270398DDOM.tif


BIN
img/DDOM/6401812024070108270399DDOM.tif


BIN
img/DDOM/6401812024070108270400DDOM.tif


BIN
img/DDOM/6401812024070108270401DDOM.tif


BIN
img/DDOM/6401812024070108270402DDOM.tif


BIN
img/DDOM/6401812024070108270403DDOM.tif


BIN
img/DDOM/6401812024070108270404DDOM.tif


BIN
img/DDOM/6401812024070108270405DDOM.tif


BIN
img/DDOM/6401812024070108270406DDOM.tif


BIN
img/DDOM/6401812024070108270407DDOM.tif


BIN
img/DDOM/6401812024070108270408DDOM.tif


BIN
img/DDOM/6401812024070108270409DDOM.tif


Some files were not shown because too many files changed in this diff