首页 > 编程问答 >在 Python 中溶解线条

在 Python 中溶解线条

时间:2024-07-22 07:16:18浏览次数:10  
标签:python gis spatial qgis polyline

我有一个包含多行的形状文件。我正在寻找一种方法来消除所有的接触线。这在 ArcMap 中是可能的,但似乎在 Python 和 QGIS 中都无法做到:

之前: enter image description here

所需的输出: enter image description here

这需要在多行上完成,因此像 QGIS 合并一样手动执行不是一个选项。

在 ArcMap 中,我曾经使用“溶解”和“分段”。不需要使用任何属性。


可以使用 Python 中的 GeoPandas 和 Shapely 库来溶解线条。以下是如何操作:

import geopandas as gpd

# 使用 GeoPandas 读取的形状文件
gdf = gpd.read_file('your_lines.shp')

# 将所有线条溶解为一个几何图形
dissolved_geom = gdf.unary_union

# 从溶解的几何图形创建一个新的 GeoDataFrame
dissolved_gdf = gpd.GeoDataFrame(geometry=[dissolved_geom])

# 将溶解的 GeoDataFrame 保存到新的形状文件
dissolved_gdf.to_file('dissolved_lines.shp')

此代码的工作原理如下:

  1. 导入必要的库: 这包括 GeoPandas 用于地理空间数据操作。
  2. 使用 geopandas.read_file() 读取的形状文件: 这将创建一个包含的线条数据的 GeoDataFrame。
  3. 使用 unary_union 属性溶解线条: 此属性在 GeoSeries(在本例中是 GeoDataFrame 的“几何图形”列)上可用,并返回代表所有几何图形联合的单个几何图形。
  4. 从溶解的几何图形创建新的 GeoDataFrame: 这是为了方便保存结果。
  5. 使用 to_file() 将溶解的 GeoDataFrame 保存到新的形状文件: 这将创建一个包含溶解线条的新形状文件。

此方法将溶解的所有线条,而无需考虑它们的属性。如果需要基于某些属性进行溶解,可以先使用 dissolve() 方法,并指定要溶解的列。

例如,如果的形状文件有一个名为“group”的列,并且想按该列溶解线条,可以执行以下操作:

dissolved_gdf = gdf.dissolve(by='group')

这将创建一个新的 GeoDataFrame,其中“group”列中的每个唯一值都有一行,并且几何图形将是该组中所有线条的溶解。

标签:python,gis,spatial,qgis,polyline
From: 65684108

相关文章

  • 一个简单的问题(python、串行通信和arduinos)
    只是一个关于小脚本的快速问题,由于某种原因无法工作我运行了这个脚本:importserialimporttimeimportturtledefserialreading():serialPort=serial.Serial(port="COM5",baudrate=9600,bytesize=8,timeout=2,stopbits=serial.STOPBITS_ONE......
  • 我在 Windows 10 上运行 Python 代码后控制台立​​即关闭
    虽然我在代码末尾使用input(),但在Windows10(IDLE之外)的窗口中输入名称后,控制台仍然立即关闭,并且我看不到结果。我该怎么做才能阻止控制台关闭?#!python3name=input('Enteryourname:')print('Hello'+name)input('pressEntertoexit:')你在代码末尾......
  • 具有未定义嵌套列表深度的嵌套列表的Python注释类型
    [[1,2,3],3,[2,4],5]的类型是list[list[int]|int]但是,如果嵌套列表具有未定义的深度,例如[[[1,2]],2,[1,[3,[3]]]],3,[2,[2]]],那么它会具有什么类型?可以使用递归类型提示来表示任意深度嵌套的列表:fromtypingimportList,Union......
  • 在Spyder(Python 3.6)中导入cv2时出现导入错误
    我已经在Windows操作系统中安装了opencv3.0.0。我已运行该应用程序并已成功将其安装在C:\驱动器中,并且还将cv2.pyd文件复制到C:\Python27\Lib\site-packages中,正如我在几个教程视频中看到的那样在我的Python2.7.5Shell中,即当我键入>>>i......
  • Python + VS Code 调试器:可视化我的程序当前正在执行的源代码中的位置?
    当我使用VSCodePython调试器时:我可以执行我的程序,以便编辑器将我逐行带到源代码中的任何位置(跳转到相关文件/如果尚未打开则将其打开)目前的执行情况是?是的,VSCode的Python调试器可以让你逐行执行代码,并实时显示当前执行的位置。以下是操作方法:1.设置断点:......
  • 如何立即取消使用 Ollama Python 库生成答案的 Asyncio 任务?
    我正在使用Ollama通过OllamaPythonAPI从大型语言模型(LLM)生成答案。我想通过单击停止按钮取消响应生成。问题在于,只有当响应生成已经开始打印时,任务取消才会起作用。如果任务仍在处理并准备打印,则取消不起作用,并且无论如何都会打印响应。更具体地说,即使单击按钮后,此函数......
  • 使用 np.array 索引过滤 Python 列表
    谁能向我解释一下列表self.data如何使用numpy索引数组selec_idx进行索引/过滤?完整的课程可在https://github.com/kaidic/LDAM-DRW/blob/master/imbalance_cifar.pydefgen_imbalanced_data(self,img_num_per_cls):new_data=[]n......
  • 尝试在cmd(python)中安装turtle
    当我在cmd中编写pipinstallturtle后,这条消息出现在我面前。有人知道该怎么办吗?C:\>pipinstallturtleCollectingturtleUsingcachedturtle-0.0.2.tar.gz(11kB)ERROR:Commanderroredoutwithexitstatus1:command:'C:\Users\Bruger\App......
  • Python + Polars:如何有效地“fill_null”仅 DataFrame 的某些列?
    例如,假设我只想fill_null(strategy="zero")DataFrame的数字列。我当前的策略是这样做:final_df=df.select(cs.exclude(cs.numeric()))final_df.with_columns(df.select(cs.numeric()).fill_null(strategy="zero"))是否有替代的、更惯用或更有效的方法来实现我......
  • 如何找到 Windows 上 Python 的安装位置?
    我想找出我的Python在Windows上的安装路径。例如:C:\Python25如何找到Python的安装位置?在Windows上查找Python安装位置的方法有很多种:1.使用where命令(推荐方法):打开命令提示符(cmd)。输入以下命令并按回车键:wherepython......