一、背景

在进行区域土地开发时,需要对整个区域的土壤稳定性评估。应用GIS空间分析方法,能够快速有效地对影响土壤稳定性的因子进行制图并评估打分,通过构建评价体系,利用叠加分析,形成土壤稳定性专题图,以为土地开发保护提供决策支持。

二、数据

某区域的数字高程模型和土地利用图,数字高程模型为GRID格式数据,土地利用数据为landuse. shp(\Chp13\Ex3\)。

三、要求

经专家研究,土壤稳定性评估原则如下:

(1)坡度越陡,稳定性越低。坡度分级临界值分别为:3、6°、11°、20°和30°;

(2)阴坡比阳坡稳定;

(3)土地利用类型的稳定性级别由高到低分别为:森林、水域、草原、居住用地和农耕地。

各个因子的量化分值随地理位置、重要性程度、所占比例等的不同而需分别制定,本例中使用的分值及权重见下文。最后要求做出土壤稳定性级别图,级别的制定也需人为确定,这里不做具体规定,重在了解问题解决思路和过程。

四、工作流程

基于DEM提取坡度数据,按照分级临界值进行重分类,并对每个坡度区间设定权重值;基于DEM提取坡向数据,重分类划分阴阳坡,并对两个坡向设定权重值。

将土地利用的矢量数据按照土地利用类型转换为栅格数据,再重分类设定每种土地利用类型的权重值。

综合坡度、阴阳坡和土地利用类型进行空间叠加分析加权求和,得到该区域土壤稳定性数据,最终划分等级制作土壤稳定性专题图。

工作流程如下图所示:

五、模型构建器

六、ArcPy实现

  1. # -*- coding: utf-8 -*-
  2. # ---------------------------------------------------------------------------
  3. # 13-3 土壤稳定性评估.py
  4. # Created on: 2021-10-12 15:28:28.00000
  5. # (generated by ArcGIS/ModelBuilder)
  6. # Description:
  7. # ---------------------------------------------------------------------------
  8. # Import arcpy module
  9. import arcpy
  10. import os
  11. import shutil
  12. import time
  13. print time.asctime()
  14. path = raw_input("请输入数据所在文件夹的绝对路径:").decode("utf-8")
  15. # 开始计时
  16. time_start = time.time()
  17. paths = path + "\\result"
  18. if not os.path.exists(paths):
  19. os.mkdir(paths)
  20. else:
  21. shutil.rmtree(paths)
  22. os.mkdir(paths)
  23. # Local variables:
  24. dem = path + "\\dem"
  25. landuse = path + "\\landuse.shp" # 注意,直接读取shapefile文件,需要加后缀格式,不然后报错
  26. Slope_dem = "Slope_dem"
  27. Rec_Slope = "Rec_Slope"
  28. Aspect_dem = "Aspect_dem"
  29. Rec_Aspect = "Rec_Aspect"
  30. land_ToRaster = "land_ToRaster"
  31. Rec_landuse = "Rec_landuse"
  32. stability = "stability"
  33. # Set Geoprocessing environments
  34. print "Set Geoprocessing environments"
  35. arcpy.env.scratchWorkspace = paths # 临时工作空间
  36. arcpy.env.workspace = paths # 工作空间
  37. arcpy.env.extent = dem # 处理范围
  38. arcpy.env.cellSize = dem # 像元大小
  39. arcpy.env.mask = dem # 掩膜
  40. # Process: 坡度
  41. print "Process: 坡度"
  42. arcpy.gp.Slope_sa(dem, Slope_dem, "DEGREE", "1", "PLANAR", "METER")
  43. # Process: 重分类
  44. print "Process: 重分类"
  45. arcpy.gp.Reclassify_sa(Slope_dem, "Value", "0 3 10;3 6 8;6 11 7;11 20 5;20 30 3;30 60 1", Rec_Slope, "DATA")
  46. # Process: 坡向
  47. print "Process: 坡向"
  48. arcpy.gp.Aspect_sa(dem, Aspect_dem, "PLANAR", "METER")
  49. # Process: 重分类 (2)
  50. print "Process: 重分类 (2)"
  51. arcpy.gp.Reclassify_sa(Aspect_dem, "Value", "-1 5;0 90 10;90 270 1;270 360 10", Rec_Aspect, "DATA")
  52. # Process: 面转栅格
  53. print "Process: 面转栅格"
  54. arcpy.PolygonToRaster_conversion(landuse, "LANDUSE", land_ToRaster, "CELL_CENTER", "NONE", dem)
  55. # Process: 重分类 (3)
  56. print "Process: 重分类 (3)"
  57. arcpy.gp.Reclassify_sa(land_ToRaster, "LANDUSE", "agriculture 2;river 8;grass 6;forest 10;urban 4", Rec_landuse, "DATA")
  58. # Process: 加权总和
  59. print "Process: 加权总和"
  60. arcpy.gp.WeightedSum_sa("Rec_Slope Value 0.3;Rec_Aspect Value 0.3;Rec_landuse VALUE 0.4", stability)
  61. save = ["stability"]
  62. rasters = arcpy.ListRasters()
  63. for raster in rasters:
  64. if raster.lower() not in save:
  65. print u"正在删除{}图层".format(raster)
  66. arcpy.Delete_management(raster)
  67. # 结束计时
  68. time_end = time.time()
  69. # 计算所用时间
  70. time_all = time_end - time_start
  71. print time.asctime()
  72. print "执行完毕!>>><<< 共耗时{:.0f}分{:.2f}秒".format(time_all // 60, time_all % 60)

七、结果





再简单丰富一下色彩:



制作土壤稳定性专题地图

点击视图区左下角的【布局视图】按钮点或点击【菜单栏】|【视图】|【布局视图】,将视图切换为布局视图。仅显示 stability.图层;将stability图层的标签名称改为“土壤稳三定性等级”,选中图层数据框后逐个添加:“指北针”、“比例尺”“图例”及“图名”,制作过程略。

实验结束 byebye~~~

土壤稳定性评估(ArcPy实现)的更多相关文章

  1. Testing - 软件测试杂谈

    Part-1 起步 测试是发现质量问题.分析.跟踪.推动与解决的过程. 1 熟悉业务,设计优质的测试用例,需要对所测试项目的业务需求非常熟悉 了解整个产品的研发和测试流程 全程参与,对需求.设计.开发 ...

  2. 如何发现 Kubernetes 中服务和工作负载的异常

    大家好,我是来自阿里云的李煌东,今天由我为大家分享 Kubernetes 监控公开课的第二节内容:如何发现 Kubernetes 中服务和工作负载的异常. 本次分享由三个部分组成: 一.Kuberne ...

  3. 新作!分布式系统韧性架构压舱石OpenChaos

    摘要:本文首先以现今分布式系统的复杂性和稳定性的需求引出混沌工程概念,并阐述了OpenChaos在传统混沌工程上的优化与创新. 背景 随着Serverless,微服务(含服务网格)与越来越多的容器化架 ...

  4. NET架构师的基本职责

    NET架构师的基本职责1 职责 对本公司大健康平台提出技术研究及可行性报告; 结合需求设计高扩展性.高性能.安全.稳定.可靠的技术系统; 可以通过配置实现业务需求的变化,跟踪并研究***并应用于产品; ...

  5. 【转】利用Pspice分析放大器环路的稳定性

    文章来源: http://www.21ic.com/app/test/201108/90808.htm 虽然在较低频率下可以较轻松地检查一个简单放大器的稳定性,但评估一个较为复杂的电路是否稳定,难度可 ...

  6. 使用jmeter对ActiveMQ集群性能方案进行评估--转载

    原文地址:http://www.51testing.com/html/78/23978-143163.html 1.测试概要1.1 关于这篇文档中涉及的基于JMS的消息系统能为应用程序提供可靠的,高性 ...

  7. Delphi 6 Web Services初步评估之三(转)

    Delphi 6 Web Services初步评估之三(转)   Delphi 6 Web Services初步评估之三(转)★ 测试总体印象:在整个测试中,对Delphi 6创建的Web Servi ...

  8. Linux转发性能评估与优化-转发瓶颈分析与解决方式(补遗)

    补遗 关于网络接收的软中断负载均衡,已经有了成熟的方案,可是该方案并不特别适合数据包转发,它对server的小包处理非常好.这就是RPS.我针对RPS做了一个patch.提升了其转发效率. 下面是我转 ...

  9. app测试--稳定性测试

    稳定性测试的概念有2种, 一, 稳定性测试,对应于异常性测试,即发生异常情况时,系统如何反应的测试.包含: 1 交互性测试,被打扰的情况,如来电,短信,低电量等.这些其实在上章的功能测试中有提到. 2 ...

随机推荐

  1. 安装完anaconda之后找不到启动图标

    安装anaconda的过程中,选择了only me模式,安装完之后找不到启动图标,安装网上的方法: 在命令行输入 conda update menuinstconda install -f conso ...

  2. for循环操作(for...in、forEach)

    1.for...in语句用于对数组或者对象的属性进行循环操作,是for循环的一种. 注意:该方法可用于数组或对象. 语法:  for(变量 in 对象/数组){} 如: var obj = { nam ...

  3. 【Tools】Anaconda Operaction

    专为数据科学和机器学习工作流程而设计,是一个开源包管理器,环境管理器,以及Python和R编程语言的分发.它通常用于大规模数据处理,科学计算和预测分析.pip install xxx ,在特定环境里使 ...

  4. mysql switch语句

    SELECT CASE the_order_status WHEN 4 THEN '待收货' WHEN 5 THEN '已收货' ELSE '其他' END AS statuss ,order_id ...

  5. MVC模式职责分工及学习路上的一些感想

    在正文之前想先说说自己coding道路上的一点感想,不得不感慨一下时间过得很快,之前写过一篇关于JavaWeb_MVC模式的一篇博客,转眼之间时间已经过去了两个月,那时候还是一个刚刚接触JavaWeb ...

  6. Vue Abp vNext获取当前登录用户

    系统默认提供了获取当前用户的api方法 https://localhost:44364/api/identity/my-profile 手工实现方法:abp后台获取当前用户需要在AppService应 ...

  7. python库--flask--创建嵌套蓝图

    这里没有对内容进行py文件分割, 可以自己根据框架自己放入对应位置 以下代码生成一个 /v1/myapp/test 的路由 from flask import Flask app = Flask(__ ...

  8. Typeora 图床设置

    Typeora 文章中的图片 使用 Github 作为图床. 使用 PicGo 上传图片到 Github 并获取图片链接. 设置 Typeora 的上传服务. 一.Github 作为图床 创建 Rep ...

  9. mysql忘记root密码连接本地库

    http://www.cnblogs.com/zf2011/archive/2012/03/13/2393387.html 今天想做个小项目,决定用mysql数据库,但是好久没用mysql了,也忘掉了 ...

  10. java中避免集合死链调用

    目录 1. 前言 2. 场景 3. 环境 3.1 开发环境准备 3.2 数据准备 3.2.1 Mysql数据库表及数据 3.2.2 redis库数据 4. 解决方式 5.完整代码 5.1Model 5 ...