ImageVerifierCode 换一换
格式:DOCX , 页数:49 ,大小:438.22KB ,
资源ID:12320422      下载积分:8 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-12320422.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(ArcGIS中Python脚本学习.docx)为本站会员(b****6)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

ArcGIS中Python脚本学习.docx

1、ArcGIS中Python脚本学习初学入门ArcGIS中Python脚本的使用By:飞天小猪写在前面的话一直想学习ArcGIS中的Python脚本,大四下半学期终于有了时间,可是想找到这么一本好的教材不容易。茫茫互联网,终于找到了旧金山州立大学Jerry Davis教授的个人主页,对其中Geoprocessing Scripts With Python如获至宝,独乐乐不如众乐乐,现在将其教程翻译并结合自己的学习情况给出总结。希望能够给更多想学习Python的同学一个参考。另外,在我刚开始接触Python时,是看了台湾辅仁大学一位老师的视频课件,在此致谢。我想从两个大部分总结:一、Python语

2、言基础;二、ArcGIS&Python。其中第一部分参考了Python精要参考(第二版)、Python编程金典(读书笔记)等书籍文献。对于多数读者来说,可能或多或少有一些编程基础,所以理解起来应该不成问题。文中多数数据来自Jerry Davis教授的主页,放在“C:prog”目录下,为了直观,我将运算结果一并编辑,方便参考。值得一提的是ArcGIS的在线帮助文档,一个实时更新的GIS宝库,很多专业性知识都可以找到答案,点击链接ArcGIS10中文帮助、ArcGIS9.3.1或9.3英文帮助。 获取更过脚本例子来学习 :ESRI的地理处理模型和脚本工具库是个不错的选择。由于我也是初次接触,翻译或

3、者心得难免有纰漏之处,希望同仁们可以多多交流!前言在GIS建模或GIS数据管理中,你可能经常需要处理一系列步骤才可以完成的工作;你可能有一个工作目录下的数据需要重投影、裁剪到研究区域,或者用某种方法组合成期望的结果;我们也经常需要根据不同情形用不同方法处理数据,因此我们需要作出选择,而高质量的决策需要考虑很多低水平的决策,这可以通过脚本程序模型辅助完成。脚本编程的主要目的是使枯燥的处理数据工作自动化,通过逻辑来指挥处理过程。我想自动化和逻辑是关键,它们区别于我们多数使用计算机时的交互活动。我们发E-mail,写文章或者设计地图,都需要和计算机交互,而处理一系列数据,我们需要自动化和利用逻辑来指

4、导自动化。在地理处理脚本逻辑中,我们需要在允许我们做的事情中作出决定,比如,处理栅格数据不同于矢量数据,或为没投影的数据设置投影,或处理仅在特定时间搜集的数据集。对于重要的GIS工作来说,脚本以及其他形式的程序是必需的,而非可有可无。在接下来的联系中,我们会探索Python的使用以及创建脚本来使用ArcGIS里众多的地理处理工具。所有你能在ArcToolbox或Model中使用的工具都能够用在Python脚本中,这些脚本可以生成脚本工具,像其他地理处理工具一样使用。一、Python语言基础安装PythonWin,在ArcGisDesktop9.3.isoDesktopPythonWin目录下可

5、以找到PythonWin的安装程序,默认是不安装的,。同时会安装win32com以及允许任何脚本在基于Dispatch的地理处理过程中工作。ArcGIS10中引入了全新的Python Window来增强内嵌的Python体验。警告:不要尝试更新随ArcGIS安装的Python到一个新的版本!下面介绍Python的一些简单语法和规则。1数学运算符Python提供了多样化的通用数学运算符多数编程语言的特征,以及许多通过import的modules提供的符号。常用的有+,-,*,/,*(幂),%(取模,即除后的余数)。下面的表格显示了整型(Integer)和浮点型(Float)各种组合运算的结果,记

6、住一条规则,只要参与运算的有浮点型,则结果为浮点型;全为整型时,结果才为整型。输入表达式结果Notes2+35整型结果2.+35.02.是浮点型,结果浮点型2-3-12*36整型结果2.*36.0浮点型5/22整型5./22.55%21取模Az=270Newaz=az+180Print newaz%36090取模的用途之一方位角加180后逆转方向5*22525*0.55.0没有sqrt()功能,除非添加math模块2字符串操作注:使用Python帮助:有超过30种内置方法来处理字符,请到Sequence Types下的String Methods寻找帮助!字符串是一串字母,比如San Fran

7、cisco,字符串下标从0开始。学习字符串语法的最好方法是自己动手尝试,下标展示之:输入结果Notesprint zhulj.capitalize()Zhuljs.capitalize()即将capitalize()方法用于ss=zhuljprint s.capitalize()print s0zStrings可以像一个字母列表一样处理,第一个字母下标为0,某个字符段可以用1:3来格式化:从第1个的开头到第3个的开头,不包括下标为3的字母;s-1表示倒过来第一个,相当于slen(s)-1s1=s1print s1hprint s-2:ljprint s2:3uprint s2:4ulprint

8、 s2:,s:5ulj zhuljs2=s.upper()print s2ZHULJ我们可以将字符串方法的结果赋给新的变量s3=s+s2print s3zhuljZHULJ字符串组合用“+”print s*3zhuljzhuljzhulj字符串重复用“*”,后为重复次数selstr=elev1000print selstrelev1000字符串可以使用单引号或双引号,跨行时用双引号。othersel=”elev1000”print otherselelev1000print s.isupper()False一些方法返回值为布尔型(True或False),一些返回索引值(下标值)print s2

9、.isupper()Truep=d:/work/lu.shpprint p.find(.)10print p.find(/)2plist=p.split(/)print plistd:, work, lu.shp你可以用split()方法解析出不同的字符串片段,并创建一个列表(List),我们可以使用其中不同的元素print plist0d:print plist1workp2=d:worksoil.shpprint p2d:worksoil.shp反斜线“”和某些字母一起有特殊用法,如n为换行,“”为转义字符,如“”则表示“”print Jerrys KidsJerrys Kidsprint

10、 JerrysnKidsJerrysKidsp3=rd:worksoil.shpprint p3d:worksoil.shp字符串前加“r”则强制“”代表其本身,而非转义字符,这对于文件路径的操作很方便3模块的使用(Modules)Python提供了一系列内置的方法(大量依赖于模块)用于通用编程。Python安装时自带了大量Modules,最常用的有math,sys,random,array以及os.path。当然还有好多Modules可以下载,比如数字处理(Numeric)numpy,可在www.python.org或里搜索。www.python.org/moin/NumericAndSci

11、entific页面中列举了一些。使用Module前,必须import之。通常我们会将一行import 放在程序顶部,比如:import arcgisscripting当然,这不必成为你程序的第一行,但必须在使用它里面方法之前。当要引用多个模块是,中间用逗号分隔,比如:import arcgisscripting,sys,string,os,math我们也可以自己为频繁使用的方法创建Module,下面,我们开始体验内置的Modules。math和random模块很多常用的数学计算功能都可以通过math找到,比如三角计算或对数计算,如果要使用复杂数字,就使用cmath模块。和之前一样,通过以下表格

12、来体现模块的使用:输入结果Notesimport mathprint math.log10(100)2.0以10为底的对数print math.log(100)4.599自然对数print math.pi3.是一个静态常量,所以不需要括弧pi=math.piprint pi3.如果不想总是输入“math.pi”可以将其赋给一变量pi3.不需要print即可查看变量值print math.sin(radians)print math.cos(radians)print math.tan(radians)三角函数的计算是弧度制degrad=pi/18045*degrad0.785398度转化为弧度

13、sin=math.sinsin(45*degrad)sin(90*degrad)0.61.0即使功能函数(像sin)都可以赋给一个变量math.e2.71828math.hypot(3,4)5.0此方法是求三角形的斜边x1=520382;y1=4152373x2=520475;y2=4152963不同赋值语句间用“;”分隔xr=x2-x1yr=y2-y1math.hypot(xr,yr)math.sqrt(xr*2+yr*2)(xr*xr+yr*yr)*0.5597.956189不同的方式,相同的结果import randomrandom.random()0.8random()方法,每次结果都

14、不同,值域为0.0,1.0)rnd=random.randomrnd()0.mu=50s=10print random.gauss(mu,s)46.44使用def构建函数有点像Module,但更简单,函数是一个自己定义功能,用在之后的代码中,并且提供任何你想要使用的参数。这个函数从此可像变量那样在程序中使用,结合例子更容易理解。接下来的代码定义了一个将度转换为弧度的简单函数,同时也定义了一个弧度转换为度的函数,它们和Excel内置的函数类似。import mathdef radians(angdeg): return angdeg*math.pi/180def degrees(angrad):

15、 return angrad*180/math.piprint math.sin(radians(45)print degrees(math.acos(0.5) 运行之,得到结果:0.1187 60.0 5流程控制结构:If,While,For任何脚本或编程语言的一个重要特征就是执行一系列不同情形语句的能力。你想要创建一系列山影栅格来代表夏天、冬天和春秋分。山影(hillshade)工具需要有太阳高度角和方位角作为输入参数。重要日期太阳倾角夏至(6月21日)23.44春秋分(3月21日,9月21日)0冬至(12月21日)-23.44接下来是一段相当简单的代码,通过太阳倾角(太阳光线正午垂直照射

16、的纬度)获取太阳角和方位角以及纬度。输入两个参数:lat(研究区域的纬度,南半球为负)和decl(太阳倾角),由此得到sunangle和azimuth:lat=30decl=20sunangle=90-lat+declazimuth=180if sunangle90: sunangle=180-sunangle azimuth=0print sunangle,azimuth 上面的例子中lat和decl强制赋了值。 有三种流程控制操作:if 仅在一个特定情形下才执行语句;while 当一种情形存在下,持续执行语句for 遍历一系列值这些语法和def有些相似:初始语句后加顿号、需要执行的语句块有

17、缩进。这三个结构的一些重要的公共特征:if、while、for语句均以冒号结尾,接下来是缩进的代码块,用于if、while、for定义的情形。在脚本编写窗口,你会发现,你在一行末尾打上冒号后,下一行自动缩进,在接下来的一行按下退格键取消缩进。如果你只需做一件事情,你可以在冒号后面同一行添加简短的语句,比如: if x0: print x 比0大 print 下一行不要缩进了。if(continued)接下来,我们会探索一下另一个方便的模块:os.path: 开始之前,在d:/下创建一个“testfolder”文件夹,然后新建一个“test.txt”文件; 尝试以下代码段,确保print语句前有

18、缩进。import os.pathif d:/testfolder/test.txt): print 测试文件夹存在 print txt文件存在elif d:/testfolder): print 测试文件夹存在 print 测试文件夹存在,但txt文件不存在else: print 两者都不存在可选探索示例接下来的例子做的事情对GIS非常重要,但是实际上不用任何地理处理代码。USGS7.5米分辨率DEM(数字高程模型)是文本文件(USGSDEM文件),投影为UTM,UTM北向和东向单位是米,但是高程单位可能是英尺(feet)或米(meters)。因此在获取垂直或水平距离信息时会有问题,比如坡度

19、可以通过垂直距离/水平距离获得。如果你不在使用Z值之前设置为0.3048,将会出现错误结果。但是不幸的是,你可能不知道DEM文本文件的垂直单位是英尺还是米。这些信息保存在第539个字符里,“1”代表英尺,“2”代表米,所以可以通过读取这个文件判断。下面的脚本演示了上述内容:import fileinputinfile=rc:progpendatawoodside.demfirstline=fileinput.input(infile)0unitchar=firstline539unit=(unknown:not a 7.5 DEM?)if unitchar=1:unit=feetif unit

20、char=2:unit=metersprint nElevation in+ +unitfileinput.close()输出结果:Elevation in feetwhile(continued) 运行下面的代码,说明了一种while循环:x=1while x10: print x x=x+1屏幕依次输出19 下面说明一下“=”(等于)的概念:x=5z=x=4print z输出Falsex=5z=x=5print z输出True“=”是逻辑运算符之一,其他有“”(大于)、“=”(大于或等于)、“=”(小于或等于)、“”(不等于)。使用逻辑运算符计算得到结果为布尔型:true(1)和false

21、(0)。下面例子简单体会一下布尔型表达式:x=1while x10: print x x=x+1表达式“x10”结果是true或false,所以这样允许我们在计算完一种情况时运行一系列代码。许多情况下我们需要使用条件代码。while循环的一个优点是允许我们跳过整个部分,如果条件不满足初始情况。由于while提供一种容易结束循环的方法,我们甚至用它代替if语句。当循环一个数据集时(GIS中很常用的工作)while循环很有用。在后面地理处理中我们会接触一些例子。for 尝试下面代码,演示了for循环:for x in 1,2,3,4:(注:1,2,3,4用range(1,5)代替是一样的) msg

22、=hello worldprint str(x)+ +msg(注:当我们希望一个数字x和字符串连接时,必须先对数字进行格式转换即str(x),否则系统报错) 下面的代码创建并输出指定文件夹内shp文件名列表(每个都以.shp结尾)import osws=c:/prog/hmbareailist=os.listdir(ws)#创建一个列表保存工作文件夹内的文件fcs=#创建一个空列表,保存结尾为.shp的文件for i in ilist: if i.endswith(.shp): fcs.append(i)for fc in fcs:print fc(输出结果如右图所示) 下面这个例子的循环较多

23、次数。变量mu是算术平均数,s是标准差这两个是random.gauss()用到的参数,可以尝试改变n的值查看结果!import randommu=50s=10z5=mu-s*1.96z95=mu+s*1.96count=0n=100000for i in range(n): x=random.gauss(mu,s) if xz95:count=count+1print float(count)/n(每次运行的结果都不同,但都在0.05左右,即统计结果在5%左右)6简单输入和输出我们现在利用前面计算太阳角代码的片段,之前是直接指定参数值,现在我们有很多种方法提供输入参数,现在我们用sys方法。尝

24、试下面的代码,点击(run运行)之后,在对话框中函数自变量(Arguments)一栏填入:40 23.44,如下图:import syslat=float(sys.argv1)decl=float(sys.argv2)#使用arguments(argv)方法从“Arguments”一栏中获取输入参数,并指定一个浮点型转换将字符型输入值传递给lat和declsunangle=90-lat+declazimuth=180if sunangle90: sunangle=180-sunangle azimuth=0print 正午太阳角=+str(sunangle)print 方位角=+str(azi

25、muth)(结果:正午太阳角=73.44 方位角=180) 二、ArcGIS&Python1如何创建地理处理对象(geoprocessor object)所有geoprocessing的Python脚本都可以通过import arcgisscripting或者win32com去穿件geoprocessor object。下面的例子显示二者区别:arcgisscripting module需要在;通过win32com创建的geoprocessor可以在不同的Python版本上运行。#9.3import arcgisscriptinggp=arcgisscripting.create(9.3)gp

26、.workspace=”c:/Tongass”gp.clip_analysis(“standb4”,”clipcov”,”standb4_clip”,”POLY”.”1.25”)#Dispatchimport win32com.clientgp=gp.workspace=”c:/Tongass”gp.clip_analysis(“standb4”,”clipcov”,”standb4_clip”,”POLY”.”1.25”) 理解ArcGIS中数据多样性格式对我们理解地理处理工具很有帮助。比如,特征数据可能是单个shp文件;geodatabase(地理数据库,我们可能指定地理数据库为工作空间)

27、;多边形、弧或点要素的coverage数据。当我们想遍历工作空间里的coverage文件时,应使用ListDatasets而不是ListFeatureClasses。2获取地理处理帮助如果你基本熟悉了Python的语法,便可以开始熟悉ArcGIS的Geoprocessing啦,获取这些方法帮助的途径有两个:1 ArcGIS帮助系统,Go To Geoprocessing/Automating your work with scripts/Scripting object:Properites and Methods.这里你会看到Geoprocessor Object,这个能让你很方便地获得所有

28、对你有用的条目、设置和其他操作文档。比如,你想得到特定类型的文件,就找到listfeatureclasses方法:fcList=gp.ListFeatureClasses(“w*”,”polygon”)注:此方法的语法为:object.ListFeatureClasses(wildCard As String, FeatureType As String) As Python List = optional wildcard为通配符,和星号(*)组合使用,如果没有通配符则返回工作目录下的所有feature classes。2 Geoprocessor Programming Model(PDF

29、),包含方法(左箭头表示)、属性(可读写的表示为杠铃形,只读的表示为部分杠铃形)2.1举例:如何使用Geoprocessor Programming Model中的ListsLists(列表)及其属性和方法在图表中用紫色标出,如下:现在我们试着编写一段脚本列举出属性表中所有属性值(Fields)(以hmbarea栅格土地利用为例,文件存在c:proghmbarea下)import arcgisscripting, sysgp = arcgisscripting.create(9.3) gp.workspace = c:/prog/hmbarea fieldList = gp.ListFields(landuse, *, all)dsc=gp.describe(landuse)print landuse+ +dsc.DataType+:for field in fieldList:. print field.Name, field.Type (此时输出结果如右图)3使用地理处理工具Toolboxes和Aliases总所周知,地理处理工具在脚本中的使用和ArcToolbox中相同,但是需要提供工具名称来

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2