资源简介
利用ArcGIS计算河流的平均比降。参考的方法是【约翰斯通-克罗斯】法

代码片段和文件信息
#############################################################
# #
# 该工具利用【约翰斯通-克罗斯】方法计算河底平均比降 #
# 在使用的时候必须先选择一条河流,工具会判断输入的河流数量 #
# 大于一条河流时不予以计算 #
# 用于计算的DEM为无凹陷点DEM #
# #
#############################################################
# -*- coding: gbk -*-
import arcpy
import math
inputLine =arcpy.GetParameterAsText(0) #河流图层
dem = arcpy.GetParameterAsText(1) #无凹陷点DEM
riverLen = 7873.232038
arcpy.AddMessage(u‘..................‘)
arcpy.AddMessage(u‘......开始执行...........‘)
# 记录高程值的数据
heightList = []
iputCout=0
mmCursor = arcpy.da.SearchCursor(inputLine [“SHAPE@LENGTH“])
for row1 in mmCursor:
riverLen = row1[0] #顺便获取河流长度
iputCout=iputCout+1
arcpy.AddMessage(u‘......获取了河流长度......‘)
#如果选中的是一个线要素,则执行计算,否者不计算多条河流
if iputCout==1:
##先将线转为折点
outLine1 = arcpy.FeatureVerticesToPoints_management(inputLine “in_memory/outline“)
arcpy.AddMessage(u‘......河流线已经转换为点集.......‘)
#河流节点
riverPoints = []
# 获取河流的节点,以用作计算高差和河长
for row in arcpy.da.SearchCursor(outLine1 [“SHAPE@XY“]):
# 从点图层数据获取所有的点的XY
x y = row[0]
#从地形数据中获取其高程的象元值
pointStr = str(x) +“ “+str(y)
result = arcpy.GetCellValue_management(dempointStr)
#print “point “+ str(vetPointL) + “ Height value is : “ + str(result)
riverPoints.append(row[0])
heightList.append(str(result))
arcpy.AddMessage(u‘......已经获取了折点的高程值......‘)
#子河段长度
subRiverList = []
hDiffList = []
# 计算每一个子河段的长度
for i in range(0len(riverPoints)-1):
xy = riverPoints[i]
x1y1 = riverPoints[i+1]
#计算河段长度
dis =math.sqrt(pow((x1-x)2)+pow((y1-y)2))
subRiverList.append(dis)
arcpy.AddMessage(u‘......河流子河段长度计算完成完成.......‘)
# 计算从高程从低到高部分的差距
listLen = len(heightList)
for j in range(0listLen-1):
h1 = float(heightList[j])
h2 = float(heightList[j+1])
xheight = 0
xheight = h1-h2
hDiffList.append(xheight)
arcpy.AddMessage(u‘......各折点的高程差计算完成......‘)
# 计算每个河段的比降
subbijiang = []
for i in range(len(hDiffList)):
Si= hDiffList[i]/subRiverList[i]
subbijiang.append(Si)
arcpy.AddMessage(u‘......子河段比降计算完成......‘)
# 计算最终的比降
# 计算分子
sumUp = 0
for i in range(len(hDiffList)-1):
sumUp = sumUp + subRiverList[i]*pow(subbijiang[i]0.5)
S = pow((sumUp/riverLen)2)
arcpy.AddMessage(u‘......该河流的总长为: ‘ + str(riverLen)+u‘ 平均比降为: ‘ +str(S))
arcpy.AddMessage(u‘......计算完毕.......‘)
else:
arcpy.AddMessage(u‘......您选中了 ‘+str(iputCout) + u‘ 条河流......‘)
arcpy.AddMessage(u‘......工具已经停止计算没有算出您想要的结果......‘)
arcpy.AddMessage(u‘......因为您目前选中了多条河流。只能选中一条河流进行计算!......‘)
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
目录 0 2017-07-11 16:49 河流平均比降计算工具BY李远祥\
文件 12800 2017-07-11 16:47 河流平均比降计算工具BY李远祥\平均比降计算工具By李远祥.tbx
文件 3751 2017-07-11 14:01 河流平均比降计算工具BY李远祥\比降计算脚本.py
- 上一篇:毕业设计周报
- 下一篇:图片识别-感知哈希算法
相关资源
- ArcGIS Engine最优路径分析
- arcgis engine实现叠加分析
- arcgis 10.1 中文环境安装包
- Arcgis 扩展模块
- shp转cad小工具
- 插件式GIS应用框架的设计与实现&mda
- 中国工具——gis插件
- ArcGiS手把手教程三——配准和矢
- arcgis_workstation地址
- ArcGIS_ArcInfo_9.3_Workstation_DVD_BT
- 全国耕地质量大数据平台
- arcpy语法教程入门以及ArcGIS的脚本构建
- ArcGis 编辑过程自动保存插件
- ArcGIS10.3 AfCore.dll重要破解文件
- 广东电子地图.rar
- 基于ArcGIS Engine的三维校园路灯管理系
- 全国省级市级县级矢量地图数据
- 完整的中国矢量地图gis数据
- 中国省市县ArcGIS地图数据(县边界线
- 中国ArcGIS数据
- ArcGIS10服务器未运行的最佳解决办法
- ArcGIS可打开并使用的世界地图
- ArcGIS空间分析基本操作
- 长江经济带shp.zip
- arcgis批量出图
- ArcGIS超级工具1.7.exe
- ArcGIS-温度划分梯度.pdf
- ArcGIS全套图标4000+
- 汤国安arcgis教程
- 山东省矢量图
评论
共有 条评论