Python脚本入门学习经典手册.docx
- 文档编号:23248428
- 上传时间:2023-05-15
- 格式:DOCX
- 页数:42
- 大小:40KB
Python脚本入门学习经典手册.docx
《Python脚本入门学习经典手册.docx》由会员分享,可在线阅读,更多相关《Python脚本入门学习经典手册.docx(42页珍藏版)》请在冰豆网上搜索。
Python脚本入门学习经典手册
Python脚本使用详解
写在前面的话
一直想学习ArcGIS中的Python脚本,大四下半学期终于有了时间,可是想找到这么一本好的教材不容易。
茫茫互联网,终于找到了旧金山州立大学JerryDavis教授的个人主页,对其中《GeoprocessingScriptsWithPython》如获至宝,独乐乐不如众乐乐,现在将其教程翻译并结合自己的学习情况给出总结。
希望能够给更多想学习Python的同学一个参考。
另外,在我刚开始接触Python时,是看了台湾辅仁大学一位老师的视频课件,在此致谢。
我想从两个大部分总结:
一、Python语言基础;二、ArcGIS&Python。
其中第一部分参考了《Python精要参考(第二版)》、《Python编程金典(读书笔记)》等书籍文献。
对于多数读者来说,可能或多或少有一些编程基础,所以理解起来应该不成问题。
文中多数数据来自JerryDavis教授的主页,放在“C:
\prog”目录下,为了直观,我将运算结果一并编辑,方便参考。
值得一提的是ArcGIS的在线帮助文档,一个实时更新的GIS宝库,很多专业性知识都可以找到答案,点击链接ArcGIS10中文帮助、或英文帮助。
获取更过脚本例子来学习:
ESRI的地理处理模型和脚本工具库是个不错的选择。
由于我也是初次接触,翻译或者心得难免有纰漏之处,希望同仁们可以多多交流!
前言
在GIS建模或GIS数据管理中,你可能经常需要处理一系列步骤才可以完成的工作;你可能有一个工作目录下的数据需要重投影、裁剪到研究区域,或者用某种方法组合成期望的结果;我们也经常需要根据不同情形用不同方法处理数据,因此我们需要作出选择,而高质量的决策需要考虑很多低水平的决策,这可以通过脚本程序模型辅助完成。
脚本编程的主要目的是使枯燥的处理数据工作自动化,通过逻辑来指挥处理过程。
我想自动化和逻辑是关键,它们区别于我们多数使用计算机时的交互活动。
我们发E-mail,写文章或者设计地图,都需要和计算机交互,而处理一系列数据,我们需要自动化和利用逻辑来指导自动化。
在地理处理脚本逻辑中,我们需要在允许我们做的事情中作出决定,比如,处理栅格数据不同于矢量数据,或为没投影的数据设置投影,或处理仅在特定时间搜集的数据集。
对于重要的GIS工作来说,脚本以及其他形式的程序是必需的,而非可有可无。
在接下来的联系中,我们会探索Python的使用以及创建脚本来使用ArcGIS里众多的地理处理工具。
所有你能在ArcToolbox或Model中使用的工具都能够用在Python脚本中,这些脚本可以生成脚本工具,像其他地理处理工具一样使用。
一、Python语言基础
安装PythonWin,在…\目录下可以找到PythonWin的安装程序,默认是不安装的,。
同时会安装win32com以及允许任何脚本在基于Dispatch的地理处理过程中工作。
ArcGIS10中引入了全新的PythonWindow来增强内嵌的Python体验。
警告:
不要尝试更新随ArcGIS安装的Python到一个新的版本!
下面介绍Python的一些简单语法和规则。
1数学运算符
Python提供了多样化的通用数学运算符——多数编程语言的特征,以及许多通过import的modules提供的符号。
常用的有+,-,*,/,**(幂),%(取模,即除后的余数)。
下面的表格显示了整型(Integer)和浮点型(Float)各种组合运算的结果,记住一条规则,只要参与运算的有浮点型,则结果为浮点型;全为整型时,结果才为整型。
输入表达式
结果
Notes
2+3
5
整型结果
2.+3
2.是浮点型,结果浮点型
2-3
-1
2*3
6
整型结果
2.*3
浮点型
5/2
2
整型
5./2
5%2
1
取模
Az=270
Newaz=az+180
Printnewaz%360
90
取模的用途之一——方位角加180后逆转方向
5**2
25
25**
没有sqrt()功能,除非添加math模块
2字符串操作
注:
使用Python帮助:
有超过30种内置方法来处理字符,请到SequenceTypes下的StringMethods寻找帮助!
字符串是一串字母,比如’SanFrancisco’,字符串下标从0开始。
学习字符串语法的最好方法是自己动手尝试,下标展示之:
输入
结果
Notes
print'zhulj'.capitalize()
Zhulj
()即将capitalize()方法用于s
s='zhulj'
print()
prints[0]
z
Strings可以像一个字母列表一样处理,第一个字母下标为0,某个字符段可以用1:
3来格式化:
从第1个的开头到第3个的开头,不包括下标为3的字母;s[-1]表示倒过来第一个,相当于s[len(s)-1]
s1=s[1]
prints1
h
prints[-2:
]
lj
prints[2:
3]
u
prints[2:
4]
ul
prints[2:
],s[:
5]
uljzhulj
s2=()
prints2
ZHULJ
我们可以将字符串方法的结果赋给新的变量
s3=s+s2
prints3
zhuljZHULJ
字符串组合用“+”
prints*3
zhuljzhuljzhulj
字符串重复用“*”,后为重复次数
selstr='"elev">1000'
printselstr
"elev">1000
字符串可以使用单引号或双引号,跨行时用双引号。
othersel=”’elev’>1000”
printothersel
‘elev’>1000
print()
False
一些方法返回值为布尔型(True或False),一些返回索引值(下标值)
print()
True
p='d:
/work/'
print(‘.’)
10
print(‘/’)
2
plist=('/')
printplist
['d:
','work','']
你可以用split()方法解析出不同的字符串片段,并创建一个列表(List),我们可以使用其中不同的元素
printplist[0]
d:
printplist[1]
work
p2='d:
\\work\\'
printp2
d:
\work\
反斜线“\”和某些字母一起有特殊用法,如\n为换行,“\”为转义字符,如“\\”则表示“\”
print'Jerry\'sKids'
Jerry'sKids
print'Jerry\'s\nKids'
Jerry's
Kids
p3=r'd:
\work\'
printp3
d:
\work\
字符串前加“r”则强制“\”代表其本身,而非转义字符,这对于文件路径的操作很方便
3模块的使用(Modules)
Python提供了一系列内置的方法(大量依赖于模块)用于通用编程。
Python安装时自带了大量Modules,最常用的有math,sys,random,array以及。
当然还有好多Modules可以下载,比如数字处理(Numeric)——numpy,可在或里搜索。
页面中列举了一些。
使用Module前,必须import之。
通常我们会将一行import
importarcgisscripting
当然,这不必成为你程序的第一行,但必须在使用它里面方法之前。
当要引用多个模块是,中间用逗号分隔,比如:
importarcgisscripting,sys,string,os,math
我们也可以自己为频繁使用的方法创建Module,下面,我们开始体验内置的Modules。
math和random模块
很多常用的数学计算功能都可以通过math找到,比如三角计算或对数计算,如果要使用复杂数字,就使用cmath模块。
和之前一样,通过以下表格来体现模块的使用:
输入
结果
Notes
importmath
print(100)
以10为底的对数
print(100)
自然对数
3.
π是一个静态常量,所以不需要括弧
pi=
printpi
3.
如果不想总是输入“”可以将其赋给一变量
pi
不需要print即可查看变量值
print(radians)
print(radians)
print(radians)
三角函数的计算是弧度制
degrad=pi/180
45*degrad
度转化为弧度
sin=
sin(45*degrad)
sin(90*degrad)
即使功能函数(像sin)都可以赋给一个变量
(3,4)
此方法是求三角形的斜边
x1=520382;y1=4152373
x2=520475;y2=4152963
不同赋值语句间用“;”分隔
xr=x2-x1
yr=y2-y1
(xr,yr)
(xr**2+yr**2)
(xr*xr+yr*yr)**
不同的方式,相同的结果
importrandom
()
random()方法,每次结果都不同,值域为[,
rnd=
rnd()
0.
mu=50
s=10
print(mu,s)
4使用def构建函数
有点像Module,但更简单,函数是一个自己定义功能,用在之后的代码中,并且提供任何你想要使用的参数。
这个函数从此可像变量那样在程序中使用,结合例子更容易理解。
接下来的代码定义了一个将度转换为弧度的简单函数,同时也定义了一个弧度转换为度的函数,它们和Excel内置的函数类似。
importmath
defradians(angdeg):
returnangdeg*180
defdegrees(angrad):
returnangrad*180/
print(radians(45))
printdegrees)
运行之,得到结果:
5流程控制结构:
If,While,For
任何脚本或编程语言的一个重要特征就是执行一系列不同情形语句的能力。
你想要创建一系列山影栅格来代表夏天、冬天和春秋分。
山影(hillshade)工具需要有太阳高度角和方位角作为输入参数。
重要日期
太阳倾角
夏至(6月21日)
春秋分(3月21日,9月21日)
0
冬至(12月21日)
接下来是一段相当简单的代码,通过太阳倾角(太阳光线正午垂直照射的纬度)获取太阳角和方位角以及纬度。
输入两个参数:
lat(研究区域的纬度,南半球为负)和decl(太阳倾角),由此得到sunangle和azimuth:
lat=30
decl=20
sunangle=90-lat+decl
azimuth=180
ifsunangle>90:
sunangle=180-sunangle
azimuth=0
printsunangle,azimuth
上面的例子中lat和decl强制赋了值。
有三种流程控制操作:
if仅在一个特定情形下才执行语句;
while当一种情形存在下,持续执行语句
for遍历一系列值
这些语法和def有些相似:
初始语句后加顿号、需要执行的语句块有缩进。
这三个结构的一些重要的公共特征:
①if、while、for语句均以冒号结尾,接下来是缩进的代码块,用于if、while、for定义的情形。
在脚本编写窗口,你会发现,你在一行末尾打上冒号后,下一行自动缩进,在接下来的一行按下退格键取消缩进。
②如果你只需做一件事情,你可以在冒号后面同一行添加简短的语句,比如:
ifx>0:
print‘x比0大’
print‘下一行不要缩进了。
。
。
’
if(continued)
接下来,我们会探索一下另一个方便的模块:
:
开始之前,在d:
/下创建一个“testfolder”文件夹,然后新建一个“”文件;
尝试以下代码段,确保print语句前有缩进。
import
if"d:
/testfolder/"):
print"测试文件夹存在"
print"txt文件存在"
elif"d:
/testfolder"):
print"测试文件夹存在"
print"测试文件夹存在,但txt文件不存在"
else:
print"两者都不存在"
可选探索示例
接下来的例子做的事情对GIS非常重要,但是实际上不用任何地理处理代码。
米分辨率DEM(数字高程模型)是文本文件(USGSDEM文件),投影为UTM,UTM北向和东向单位是米,但是高程单位可能是英尺(feet)或米(meters)。
因此在获取垂直或水平距离信息时会有问题,比如坡度可以通过垂直距离/水平距离获得。
如果你不在使用Z值之前设置为,将会出现错误结果。
但是不幸的是,你可能不知道DEM文本文件的垂直单位是英尺还是米。
这些信息保存在第539个字符里,“1”代表英尺,“2”代表米,所以可以通过读取这个文件判断。
下面的脚本演示了上述内容:
importfileinput
infile=r"c:
\prog\pendata\"
firstline=(infile)[0]
unitchar=firstline[539]
unit="(unknown:
nota'DEM)"
ifunitchar=="1":
unit="feet"
ifunitchar=="2":
unit="meters"
print"\nElevationin"+""+unit
()
输出结果:
Elevationinfeet
while(continued)
运行下面的代码,说明了一种while循环:
x=1
whilex<10:
printx
x=x+1
屏幕依次输出1~9
下面说明一下“==”(等于)的概念:
x=5
z=x==4
printz
输出False
x=5
z=x==5
printz
输出True
“==”是逻辑运算符之一,其他有“<”(小于)、“>”(大于)、“>=”(大于或等于)、“<=”(小于或等于)、“<>”(不等于)。
使用逻辑运算符计算得到结果为布尔型:
true
(1)和false(0)。
下面例子简单体会一下布尔型表达式:
x=1
whilex<10:
printx
x=x+1
表达式“x<10”结果是true或false,所以这样允许我们在计算完一种情况时运行一系列代码。
许多情况下我们需要使用条件代码。
while循环的一个优点是允许我们跳过整个部分,如果条件不满足初始情况。
由于while提供一种容易结束循环的方法,我们甚至用它代替if语句。
当循环一个数据集时(GIS中很常用的工作)while循环很有用。
在后面地理处理中我们会接触一些例子。
for
尝试下面代码,演示了for循环:
forxin[1,2,3,4]:
(注:
[1,2,3,4]用range(1,5)代替是一样的)
msg="helloworld"
printstr(x)+""+msg(注:
当我们希望一个数字x和字符串连接时,必须先对数字进行格式转换即str(x),否则系统报错)
下面的代码创建并输出指定文件夹内shp文件名列表(每个都以‘.shp’结尾)
importos
ws="c:
/prog/hmbarea"
ilist=(ws)#创建一个列表保存工作文件夹内的文件
fcs=[]#创建一个空列表,保存结尾为‘.shp’的文件
foriinilist:
if(".shp"):
(i)
forfcinfcs:
printfc(输出结果如右图所示)
下面这个例子的循环较多次数。
变量mu是算术平均数,s是标准差——这两个是()用到的参数,可以尝试改变n的值查看结果!
importrandom
mu=50
s=10
z5=mu-s*
z95=mu+s*
count=0
n=100000
foriinrange(n):
x=(mu,s)
ifx
count=count+1
printfloat(count)/n(每次运行的结果都不同,但都在左右,即统计结果在5%左右)
6简单输入和输出
我们现在利用前面计算太阳角代码的片段,之前是直接指定参数值,现在我们有很多种方法提供输入参数,现在我们用sys方法。
尝试下面的代码,点击(run运行)之后,在对话框中函数自变量(Arguments)一栏填入:
40,如下图:
importsys
lat=float[1])
decl=float[2])#使用arguments(argv)方法从“Arguments”一栏中获取输入参数,并指定一个浮点型转换将字符型输入值传递给lat和decl
sunangle=90-lat+decl
azimuth=180
ifsunangle>90:
sunangle=180-sunangle
azimuth=0
print"正午太阳角="+str(sunangle)
print"方位角="+str(azimuth)(结果:
正午太阳角=方位角=180)
二、ArcGIS&Python
1如何创建地理处理对象(geoprocessorobject)
所有geoprocessing的Python脚本都可以通过importarcgisscripting或者win32com去穿件geoprocessorobject。
下面的例子显示二者区别:
arcgisscriptingmodule需要在版本上创建并且需要此版本创建geoprocessor;通过win32com创建的geoprocessor可以在不同的Python版本上运行。
#
importarcgisscripting
gp=
=”c:
/Tongass”
(“standb4”,”clipcov”,”standb4_clip”,”POLY”.””)
#Dispatch
import
gp=理解ArcGIS中数据多样性格式对我们理解地理处理工具很有帮助。
比如,特征数据可能是①单个shp文件;②geodatabase(地理数据库,我们可能指定地理数据库为工作空间);③多边形、弧或点要素的coverage数据。
当我们想遍历工作空间里的coverage文件时,应使用ListDatasets而不是ListFeatureClasses。
2获取地理处理帮助
如果你基本熟悉了Python的语法,便可以开始熟悉ArcGIS的Geoprocessing啦,获取这些方法帮助的途径有两个:
1ArcGIS帮助系统,GoToGeoprocessing/Automatingyourworkwithscripts/Scriptingobject:
ProperitesandMethods.
这里你会看到GeoprocessorObject,这个能让你很方便地获得所有对你有用的条目、设置和其他操作文档。
比如,你想得到特定类型的文件,就找到listfeatureclasses方法:
fcList=(“w*”,”polygon”)
注:
此方法的语法为:
({wildCard}AsString,{FeatureType}AsString)AsPythonList
{}=optionalwildcard为通配符,和星号(*)组合使用,如果没有通配符则返回工作目录下的所有featureclasses。
2GeoprocessorProgrammingModel(PDF),包含方法(左箭头表示)、属性(可读写的表示为杠铃形,只读的表示为部分杠铃形)
举例:
如何使用GeoprocessorProgrammingModel中的Lists
Lists(列表)及其属性和方法在图表中用紫色标出,如下:
现在我们试着编写一段脚本列举出属性表中所有属性值(Fields)(以hmbarea栅格土地利用为例,文件存在c:
\prog\hmbarea下)
importarcgisscripting,sys
gp=
="c:
/prog/hmbarea"
fieldList=("landuse","*","all")
dsc=("landuse")
print"landuse"+""++":
"
forfieldinfieldList:
...print,(此时输出结果如右图)
3使用地理处理工具——Toolboxes和Aliases
总所周知,地理处理工具在脚本中的使用和ArcToolbox中相同,但是需要提供工具名称来使用它们。
但是记住一个名称可能有好几个工具,比如,裁剪工具(Clip)在Coverage->Analysis->Extract工具集里,另一个是在DataManagementTools下的Raster工具集下。
区别是每个工具适用不同的数据类型,但是我们如何在脚本中区分它们呢
在ArcToolbox中,我们可以随意选择要使用的工具,但在脚本里就必须在某些方面加以区分。
因此我们使用Aliases(别名)——已经成为工具名称的一部分。
每一个工具都有自己的别名,我们可以通过右键->属性来查看:
Aliase
Toolbox
“conversion”
Conversion
“3d”
3DAnalyst
“geocoding”
Geocoding
“analysis”
Analysis
“ga”
GeostatisticalAnalyst
“arc”
Coverage
“lr”
LinearReferencing
“management”
DataManagement
“sa”
SpatialAnalyst
“cartography”
Cartography
“stats”
SpatialStatistics
现在我们用一段脚本来解释:
importarcgisscripting,sys
gp=
=”c:
/prog/hmbarea”
=1#OverWriteOutput:
Boolean,为1表示允许覆盖已存在文件
#将streams/arc转换为shp文件
("streams/arc","")
#利用转换后的shp文件,做200米的缓冲
("","",200)
#用做过缓冲的shp裁剪
("","","")
注:
上面脚本用“#”注释的中文内容不要出现在脚本文件中,否则会出现错误
结果截图:
如果你一次使用一个工具集中的若干工具,可以通过环境设置省下一些文字:
="Analysis"
("","",200)
("","","")
4在建模中使用脚本(ScriptsinModelBuilder)
首先,需要记住的很重要的一点是,ArcToolbox里相当数量的工具实际上都是脚本。
脚本都有一个图标。
比如,空间统计分析工具(SpatialStaisticstools)几乎都是Pyt
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Python 脚本 入门 学习 经典 手册