Arcpy操作

Arcgis-Arcpy

持续更新

安装

安装步骤

基础介绍

地理信息系统(geography information system,GIS)是在计算机硬件支持下,对整个或者部分地球表层空间中的有关地理分布数据进行采集,存储,管路,运算,分析,显示和描述的技术系统。地理信息系统处理和管理的对象是多种地理空间实体数据及其关系,包括空间定位数据,图形数据,遥感图像数据,属性数据,主要用于分析和处理一定地理区域内分布的各种现象和过程,解决复杂的规划,决策的管理问题。(有些官方,看看就行)

其他:略(嘿嘿嘿,可以去看看官方文档,本文主要讲数据变换,平时的基础操作只能熟能生巧了)

  • 数据变换:对数据进行放大,缩小等几何位置,形状和方位的改变等操作。
方法描述操作方法
空间校正对于数据进行一些校正处理编辑器|空间校正|设置校正数据|设置校正方法、空间校正
橡皮页变换对两个图层或多个图层进行小型的几何校正编辑器|空间校正|设置校正数据|设置校正方法|橡皮页变换
边匹配创建两个相邻图层的位移连接编辑器|空间校正|设置校正数据|设置校正方法|边捕捉
地理配准用于栅格数据的空间位置匹配编辑器|地理配准
翻转将栅格数据通过数据中心点的水平轴线数据管理工具|投影和变换|栅格|翻转
镜像将栅格数据通过数据中心点的垂直轴线数据管理工具|投影和变换|栅格|镜像
重设比例尺将栅格数据按照指定的比例分别沿X轴和Y轴放大或缩小数据管理工具|投影和变换|栅格|重设比例
扭曲将栅格数据通过输入的控制点进行多项式变换数据管理工具|投影和变换|栅格|扭曲

自学疑惑

  1. 为什么要进行地理配准

是为了使所有的图像的坐标系统一样,从而在一个坐标系统中更好的显示数据。

  1. 为什么要建立拓扑关系

拓扑bai检查主要是检查数据的拓du扑关系是否正确且完整,如果通过检查,说明数据有完整的拓扑关系,错误的拓扑关系不存在,比如重复线,相交线的交点是断点等情况。

  1. 个人地理数据库和文件地理数据库的区别

文件bai地理数据库是ESRI公司的数据库,du存储格式为包含二进制文件的文zhi件夹,存储能力dao1TB,支持任何平台个人地理数据库存储格式为Microsoft Access,存储能力为2GB,只支持Windows平台。

  1. 为什么要建立数据库

数据组织是在数据采集之后的按照一定的方式和规则对数据进行归并,存储和处理的过程,数据处理的好坏,直接影响到GIS系统的性能。地理数据库是按照层次型的数据对象来组织地理数据,这些数据对象包括对象类(表格),要素类(要素)和要素数据类。

  1. 数据的符号化和图表化的方式显示的区别和目的

符号化:直接在图像上显示;图表化:单独建立一个图表;共同目的:让数据看起来更清晰明了。

  1. 怎么从excel里面导入数据

从catalog中的excel里面选择从XY表创建要素类。

  1. 栅格数据和矢量数据的区别

栅格数据可以是照片,用像元组成,要波段信息;矢量数据是点线面,打开会有属性表。

  1. 为什么矢量分析和栅格分析可以分析三维空间信息,但是在实际中不能用于三维空间分析

矢量数据模型三维分析方法主要是基于数学分析和图论的思想;栅格数据以矩阵计算为理论基础进行分析。当前,GIS的研究成果和应用系统主要集中于描述二维空间信息,各项技术已较为成熟,但由于二维地理信息系统将实际的三维实体采用二维表示,具有很大的局限性,大量的多维空间信息无法得到利用,因此必须用三维。

  1. 为什么要建立和验证拓扑关系

拓扑关系本身就是点线,点面,线线,线面,面面之间的关系,进行拓扑验证可以更好的验证他们之间的关系,从而更好的实施操作

  1. 拓扑错误类型以及好的解决方法

常见错误类型:面不能相互重叠,面不能有缝隙,线不能相交,线不能有悬挂,其他错误

推荐解决方法:

面不能相互重叠:在错误上右键选择 merge,将重叠部分合并到其中一个面里;

面不能有缝隙:在错误上右键选择 create feature,将缝隙部分生成一个新的要素,然后利用editor 下的 merge 把生成的面合并到相邻的一个面里;

线不能相交:部分重叠可以在错误上右键选择 subtract 去除重复部分;

线不能有悬挂:根据实际情况对线进行修改消除悬挂线;

其他错误:。

Arcgis和数据库连接

Arcpy

基础了解

  1. 判断文件是否存在
>>> result = arcpy.Exists(r'E:\arcgis 光盘\Chp3\Ex1\Blocks.shp')
>>> print(result)
  1. 判断矢量数据要素数量
>>> arcpy.GetCount_management(r'E:\arcgis 光盘\Chp3\Ex1\Blocks.shp')
>>> <Result '219'>

地图文档部分:即mxd

英语中文英语中文
map地图author作者
mapping制图summary小结
document文档description描述
mapDocument地图文档default默认
properties属性relative相对
current当前path路径
title标题relativepaths相对路径
  1. 引用和查看地图文档
>>> import arcpy
>>> import arcpy.mapping as mp
>>> mxd = mp.MapDocument('current')	# current表示是当前地图文档
>>> mxd = mp.MapDocument(file)	# 查看其它地图文档
  1. API介绍
'''
dir(object):返回当前范围内的变量,方法和定义的类型列表
str.startswith(str, beg=0, end=len(string)):检查字符串是否以指定字符串开头
hasattr(object, name):判断对象是否包含对应的属性
getattr(object, name[,defalut]):返回一个对象属性值
'''
  1. 修改地图属性
mxd.title = ur’’修改标题
mxd.author = ur’’修改作者
mxd.credits = ur’’修改单位
mxd.relativePaths = False修改相对路径
  1. 保存地图文档
地图文档保存APIMapDocument.save()
地图文档另存为MapDocument.saveACopy(filename, {version})
换个文件名保存副本mxd.saveACopy(ur’’)
# 修改文档示例
mxd.author = ur''
# 保存文档
mxd.saveACopy(ur'')

数据框部分

英语中文英语中文
data数据extent范围
frame框架zoomToSelectedFeatures缩放
dataFrame数据库selected选中
active活动的feature要素
activeDataFrame当前数据框zoomToSelectedFeatures缩放至选中要素
TOC table of contents内容列表spatialReference空间参考
refresh刷新layer图层
refreshTOC刷新内容列表geodatabase地理数据库
list列举referenceScale参考比例尺
General常规的rotation旋转角度
zoom缩放displayUnits显示单位
CGCS2000中国2000坐标系mapUnits地图单位
  1. 获取数据框的名称
>>> adf = mxd.activeDataFrame	# 获得数据框
>>> print(adf.name)		# 数据框名称
  1. 列举所有数据框
dfs = mp.ListDataFrames(mxd)
for df in dfs:
    print(df.name)
  1. 查看数据框的所有成员
callable(object) -> bool 	# 检查一个数据框是否可以调用
for i in dir(adf):
    if not i.startswith("_") and callable(getattr(adf,i)):
        print(i,getattr(adf,i))
  1. 动态旋转地图
adf.rotation		# 数据框旋转角度
acrpy.RefreshActiveView		# 刷新活动视角
time.sleep(secs)		# 推迟调用线程的运行,运行secs参数,表示进程挂起的时间
  1. 查看数据框的空间参考
adf = mxd.activeDataFrame
sr = adf.spatialReference		# 空间参考
sr.name		# 名称
u'CGCS2000_3_Degree_GK_Zone_36'		# 高斯投影
  1. 查看数据框的四至空间范围
ext = adf.extent		# 数据框范围
ext.XMin
ext.XMax
ext.YMin
ext.YMax
  1. 更改数据框显示范围以显示全图
'''
1. 主要任务
将选中要素最大化显示出来
2. 准备工作
用鼠标移动地图,并用鼠标选择钦南区
'''
adf.zoomToSelectedFeatures()		# 缩放至选中要素
arcpy.RefreshActiveView()		# 刷新活动视角
  1. 跟踪目标运动
import numpy as np
ext = adf.extent
xs = np.linespace(ext.XMin,ext.XMax,50)
ys = np.linespace(ext.YMin,ext.YMax,50)
xys = zip(xs,ys)
for xy in xys:
    x=xy[0]
    y=xy[1]
    extent = arcpy.Extent(x,y,x,y)
    adf.panToExtent(extent)
    arcpy.RefreshActiveView()	
    time.sleep()

图层部分

英语中文英语中文
Layer图层transparency透明度
len,length长度source来源
visiable可见性extent范围
description描述FeatureLayer要素图层
definition定义SelectionSet选择集
query查询symbology符号
scale比例尺label标注
min,minimum最小field字段
max,maximum最大contain包含
FID,FeatureID要素编号definitionQuery定义查询
  1. 获取地图内所有图层
lys = mp.ListLayers(mxd)		# 获得所有图层
for each in lys:
	print(each.name,)
  1. 获取数据框内所有图层
lys = mp.ListLayers(mxd, data_frame=adf)		# 获得所有图层
for each in lys:
	print(each.name,)
  1. 图层定位和模糊查询
lys = mp.ListLayers(mxd, 'mohu*')		# 获得所有图层
ly = lys[0]
print(ly)
  1. 查看图层所有成员
lys = mp.ListLayers(mxd, data_frame=adf)		# 获得所有图层
ly = lys[0]
for i in dir(ly):
    if hasattr(ly,i) and not i.startswith("_"):
        print(i,getattr(ly,i))
  1. 获取图层四至
lys = mp.ListLayers(mxd)		# 获得所有图层
ly = lys[0]
ext = ly.Extent()
print(ext.XMin,ext.XMax,ext.YMin,ext.YMax)
  1. 点和图层之间的关系
# 验证中心点在图层之内
lys = mp.ListLayers(mxd)		# 获得所有图层
ly = lys[0]
ext = ly.Extent()
x0 = (ext.XMin + ext.XMax)/2
y0 = (ext.YMin + ext.YMax)/2
p0 = arcpy.Point(x0,y0)
ext.contain(p0)
# 测试随机点和图层的关系
  1. 平移或缩放图层
adf = mxd.activeDataFrame	# 获得数据框
lys = mp.ListLayers(mxd)		# 获得所有图层
ly = lys[0]
extent = ly.Extent()
adf.panToExtent(extent)		# 平移
arcpy.RefreshActiveView()
adf.extent = extent		# 缩放
  1. 平移或缩放某一选择范围
adf = mxd.activeDataFrame	# 获得数据框
lys = mp.ListLayers(mxd)		# 获得所有图层
ly = lys[0]
adf.extent = ly.getSelectedExtent()		# 图层的选择范围
adf.panToExtent(extent)		# 平移
arcpy.RefreshActiveView()
adf.extent = extent		# 缩放
arcpy.RefreshActiveView()
  1. 选择图层的数据集
adf = mxd.activeDataFrame	# 获得数据框
lys = mp.ListLayers(mxd)		# 获得所有图层
ly = lys[0]
adf.extent = ly.getSelectionSet()		
  1. 图层的定义查询
lys = mp.ListLayers(mxd)		# 获得所有图层
ly = lys[0]
qujie.definitionQuery		# 获取定义查询

qujie.definitionQuery = '查询条件'		# 设置定义查询
arcpy.RefreshActiveView()

qujie.definitionQuery = ''		# 清除定义查询
arcpy.RefreshActiveView()

空间数据源

英语中文英语中文
DataSource数据源env环境
DataLink数据链接replace替换
Workspace工作空间overwrite覆盖
  1. 获取数据源和属性
lyr.isFeatureLayer		# 是否要素图层

print(lyr.dataSource)		# 数据源,返回路径
print(lyr.datasetName)		# 数据集名称
  1. 获取数据源的工作空间,数据集的关系
# 工作空间
import os
print(os.path.split(lyr.dataSource)[0])

print(lyr.workaspacePath)

# 数据名
print(os.path.split(lyr.dataSource)[1])
# 文件命名
print(lyr.datasetName)
# 文件类型
print(os.path.splitext(lyr.dataSource))
  1. 添加数据
arcpy.env.workspace = r'工作路径'		# 工作空间
layer = mp.Layer('区界.shp')		# shp生成layer
mp.ADDLayer(mxd.activeDataFrame,layer)		# 添加图层
  1. 插入数据
layers = mp.ListLayers(mxd)
refLyr = layers[1]

print(refLyr.name)		# 参考图层名称

arcpy.env.workspace = r'工作路径'		# 工作空间
layer = mp.Layer('区界.shp')		# shp生成layer
mp.InsertLayer(mxd.activeDataFrame,refLyr,layer,"位置(bottom)")		# 添加图层
  1. 保存图层
layer = mp.ListLayers(mxd)[1]		# 定位图层
lyr = r'路径'		# 添加图层
arcpy.env.overwriteOutput = True		# 覆盖输出
layer.saveACopy		# 保存图层
  1. 替换数据源
lyr.replaceDtaSource('','','')

文件制图

英语中文英语中文
export导出print打印
JPEG,Joint Photographic Experts Group联合图像专家组PDF,Portable Document Format便携式文档格式
ExportToPDF导出至pdfExportToJPEG导出至JPG
  1. 数据框导出为pdf文件
dfPDF = r'路径'		# 目标jpg路径
mp.ExportToPDF(mxd,dfPDF,mxd.activeDataFrame)		# 导出图片
  1. 数据框导出为jpeg文件
dfjpeg = r'路径'		# 目标jpg路径
mp.ExportToJPEG(mxd,dfjpeg,mxd.activeDataFrame)		# 导出图片
  1. 地图文档导出为图片
dfjpeg = r'路径'		# 目标jpg路径
mp.ExportToJPEG(mxd,dfjpeg)		# 导出图片
  1. 单文件批量出图
lyr.definitionQuery = '条件'		# 图层过滤
extent = lyr.getExtent()		# 获取图层范围
adf.extent = extent		# 设置数据框范围
arcpy.RefreshActiveView()
dfjpeg = r'路径'		# 目标jpg路径
mp.ExportToJPEG(mxd,dfjpeg,mxd.activeDataFrame)		# 导出图片
lyr.definitionQuery=''		# 消除过滤

后续更新

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

妖怪喜欢风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值