Python地圖柵格化實例

来源:https://www.cnblogs.com/cnpolaris/archive/2022/10/13/16789522.html
-Advertisement-
Play Games

Python地圖柵格化實例 引言 shapefile是GIS中的一種非常重要的數據類型,由ESRI開發的空間數據開放格式,目前該數據格式已經成為了GIS領域的開放標準。目前絕大多數開源以及收費的GIS軟體都支持該數據類型。事實上,shapefile文件指的一種文件存儲的方法,實際上該種文件是由多個文 ...


Python地圖柵格化實例

引言

shapefileGIS中的一種非常重要的數據類型,由ESRI開發的空間數據開放格式,目前該數據格式已經成為了GIS領域的開放標準。目前絕大多數開源以及收費的GIS軟體都支持該數據類型。事實上,shapefile文件指的一種文件存儲的方法,實際上該種文件是由多個文件組成的。組成一個shapefile有三種文件必不可少, '.shp','.shx','.dbf'文件。

geopandasshapefile提供了很好的讀取與寫出支持。geopandas庫允許對幾何類型進行空間操作,其中DataFrame結構相當於GIS數據中的一張屬性表,使得可以直接操作矢量數據屬性表,使得python中操作地理數據更加方便。本實例通過geopandas實現對地理數據的操作。

開發準備

由於geopandas庫的安裝需要一些前提庫,因此需要先安裝一些庫

pip install pipwin
pipwin install gdal
pipwin install fiona
pip install geopandas

實測以上方法可以成功在windows下安裝(註:如果在Anaconda下安裝geopandas更為方便)

數據準備

下載地址

該數據是一段GPS掃描數據,包含經緯度。

代碼實例

環境引入
import geopandas as gp
import matplotlib.pyplot as plt
from shapely import geometry
import math
GPS數據處理
lake_original_path = 'data.txt'
lake_original_data = ''
lake_points = []
# 讀取文件
with open(lake_original_path) as f:
    lake_original_data = f.read()
# 處理經緯度坐標 並以Point的形式添加到list中
for xy in lake_original_data.split(';'):
    x, _, y = xy.partition(',')
    x = float(x.strip()) / 100
    y = float(y.strip()) / 100
    lake_points.append(geometry.Point(y, x))
創建要素
# 創建線狀要素
lake_line = geometry.LineString(lake_points)
# crs指定坐標系
lake_ = gp.GeoSeries(lake_line, crs='EPSG:4326')
# 保存shp文件
lake_.to_file("boundary.shp", driver='ESRI Shapefile', encoding='utf-8')
# 記錄邊界條件 用於構建柵格
x_min, y_min, x_max, y_max = lake_line.bounds[:4]
# 繪圖
lake_.plot()
plt.show()

構建柵格
# 柵格大小
GRID_WIDTH = 0.009 * 2 / 100
grid_rows_num = int(math.ceil((y_max - y_min) / float(GRID_WIDTH)))
grid_columns_num = int(math.ceil((x_max - x_min) / float(GRID_WIDTH)))
grids = []
for r in range(grid_rows_num):
    for c in range(grid_columns_num):
        grid_4coords = []
        # 左上角
        x_lt = x_min + c * GRID_WIDTH
        y_lt = y_max - r * GRID_WIDTH
        # 右上角
        x_rt = x_lt + GRID_WIDTH
        y_rt = y_lt
        # 左下角
        x_lb = x_lt
        y_lb = y_lt - GRID_WIDTH
        # 右下角
        x_rb = x_rt
        y_rb = y_lb
        # 兩個三角形拼接一個柵格
        grid_4coords.append(geometry.Point(x_lt,y_lt))
        grid_4coords.append(geometry.Point(x_rt,y_rt))
        grid_4coords.append(geometry.Point(x_rb,y_rb))
        grid_4coords.append(geometry.Point(x_lb,y_lb))
        grid_4coords.append(geometry.Point(x_lt,y_lt))
        # 創建一個網格
        grids.append(geometry.LineString(grid_4coords))
grid_ = gp.GeoSeries(grids)
grid_.to_file('E:\\just\\海韻湖智能技術實驗場\\data\\grids.shp',driver='ESRI Shapefile', encoding='utf-8')
grid_.plot()
plt.show()

要素疊加
# 要素疊加
elements = [lake_line]
elements += grids
elements_ = gp.GeoSeries(elements)
elements_.to_file('elements.shp', driver='ESRI Shapefile', encoding='utf-8')
elements_.plot()
plt.show()

參考鏈接

python-geopandas讀取、創建shapefile文件、geopandas學習教程

GeoPandas官方文檔

基於arcpy實現導出區域內網格中心坐標功能

gepandas安裝問題


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 概念 performance.now():返回值表示為從time origin之後到當前調用時經過的時間, time origin: 時間源, 時間源是一個可以被認定為當前文檔生命周期的開始節點的標準時間,計算方法如下: 如果腳本的 global object 是 Window, 則時間源的確定方式 ...
  • 在前面隨筆《基於SqlSugar的開發框架循序漸進介紹(12)-- 拆分頁面模塊內容為組件,實現分而治之的處理》中我們已經介紹過,對於相關的業務表的界面代碼,我們已經儘可能把不同的業務邏輯封裝在不同的頁面組件中,隔離變化的差異,因此界面組件化後,就可以利用代碼生成工具進行統一的界面代碼的生成了,而且... ...
  • 應用集成是解決各個系統之間信息共用中最基礎和最重要的一步。我國的商業銀行都擁有繁多、複雜的應用系統,重覆開發的情況嚴重,而且不能很好地跨系統共用數據或功能,不利於金融創新能力的提升。本文主要介紹了應用集成的發展階段,和如何運用集成技術與方式解決系統的煙囪問題,以及相比較之下的優點與局限性。還請各路專... ...
  • 對於在父類中存在的屬性,如果要在其派生類中繼續擴展屬性 可以這樣實現 1 class Valley: 2 def __init__(self): 3 self._name = None 4 5 @property 6 def name(self): 7 return self._name 8 9 @ ...
  • 數組操作 1. 數組和 for 迴圈不得不說的秘密 數組是一個連續數據存儲空間,同時帶有下標性質操作,下標範圍是 0 ~ 數組容量 - 1 ==> 利用迴圈來進行操作。 // 利用 for 迴圈給予數組中的每一個元素進行賦值操作 // 利用 for 迴圈展示數組中的每一個元素數據存儲內容 class ...
  • Kafka介紹 Kafka是最初由Linkedin公司開發,是一個分散式、支持分區的(partition)、多副本的(replica),基於zookeeper協調的分散式消息系統,它的最大的特性就是可以實時的處理大量數據以滿足各種需求場景:比如基於hadoop的批處理系統、低延遲的實時系統、Stor ...
  • JDBC和連接池01 1.JDBC概述 基本介紹 JDBC為訪問不同的資料庫提供了同一的介面,為使用者屏蔽了細節問題 Java程式員使用JDBC,可以連接任何提供了jdbc驅動程式的資料庫系統,從而完成對資料庫的各種操作 jdbc原理圖 JDBC是java提供的一套用於資料庫操作的介面API,Jav ...
  • 大數階乘的由來 一個正整數的階乘(Factorial)是所有小於及等於該數的正整數的積,並且0的階乘為1。自然數n的階乘寫作n!。亦即n!=1×2×3×...×(n-1)×n。階乘亦可以遞歸方式定義:0!=1,n!=(n-1)!×n。 但是在求解數字較大的階乘時,由於階乘累乘的性質,導致結果過大,在 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...