《基于ArcGIS的Python编程秘笈(第2版)》——2.12 操作数据框中启用时间的图层

简介:
+关注继续查看

本节书摘来自异步社区《基于ArcGIS的Python编程秘笈(第2版)》一书中的第2章,第2.12节,作者: 【美】Eric Pimpler(派普勒) 更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.12 操作数据框中启用时间的图层

本节将介绍如何启用图层的时间属性,然后编写脚本,循环遍历图层的时间范围并导出PDF地图,用来展示以7天为间隔的犯罪数据。

2.12.1 准备工作
DataFrameTime对象可执行时间管理操作,用来管理数据框中启用时间的图层。DataFrameTime对象是引用DataFrame.time属性返回的结果,它可以检索当前时间(currentTime)、结束时间(endTime)、开始时间(startTime)、时间步长间隔(timeStepInterval)以及其他使用“TimeSliderOptions”对话框建立的属性,然后在地图文档中保存属性。数据框中的图层必须启用了时间属性才能实现这些功能。

2.12.2 操作方法
下面按步骤介绍如何操作启用时间的图层。

(1)在ArcMap中打开C:ArcpyBookCh2Crime_Ch2.mxd。

(2)在ArcMap的“Table Of Contents”窗口中确保Crime是活动的数据框。

(3)右击“Burglaries in 2009”图层,选择“Properties”,打开“Layer Properties”窗口,选择“Time”选项卡,如图2-19所示。


<a href=https://yqfile.alicdn.com/d9b9cb4a43601393d5af03b2a38b0b1648289b54.png" >

单击勾选“Enable time on this layer”复选框,启用该图层的时间属性。

(4)在“Time properties”下的“Layer Time:”选项中选择“Each feature has a single time field”;在“Time Field:”选项中选择“SPLITDT”字段;在“Time Step Interval:”选项中设置为“7.00 Days”。如图2-20所示。


32c40acbeb5be1a5c09fd2315164993875c4479d

单击“Calculate”按钮,计算“Layer Time Extent”,如图2-21所示。


<a href=https://yqfile.alicdn.com/d828a2c9180a3d6c57870790f7acbd471f0de717.png" >

(5)检查“Time Step Interval:”字段,有可能需要重置为“7Days”。

(6)单击“Apply”,然后单击“OK”。

(7)在ArcMap工具条上,单击“time slider”按钮,打开“Time Slider”窗口,如图2-22所示。在窗口中单击“time slider options”按钮,打开“Time Slider Options”对话框。


f07be950335c4b850c1f316ec17290328eb1a72a

(8)在“Time Slider Options”对话框的“Time Display”选项卡中,确定“Time step interval”设置为“7.0days”,否则重新设置为“7.0days”。“Time window”选项同样设置为“7.0days”。如图2-23所示。


80d17e5d1712fb0025548d58c5869497febcd2b8

(9)单击“OK”。

(10)保存地图文档。必须在地图文档中保存启用时间的数据,否则编写的代码无法执行。

(11)打开“Python”窗口。

(12)导入arcpy.mapping模块。

import arcpy.mapping as mapping

(13)引用当前活动的地图文档(Crime_Ch2.mxd),把该引用赋值给变量。

mxd = mapping.MapDocument("CURRENT")

(14)检索Crime数据框。

df = mapping.ListDataFrames(mxd, "Crime")[0]

(15)生成DataFrameTime对象。

dft = df.time

(16)设置DataFrameTime.currentTime属性为DataFrameTime.startTime属性。

dft.currentTime = dft.startTime

(17)在while循环内,创建一个变量存储PDF文件名称,将地图文档的数据框导出为PDF,输出导出的PDF文件名,重置currentTime属性。while循环体的完整代码如下所示。

while dft.currentTime <= dft.endTime:
        fileName = str(dft.currentTime).split(" ")[0] +
        ".pdf"

        mapping.ExportToPDF(mxd,os.path.join(r"C:\ArcpyBook\Ch2",
        fileName), df)
        print("Exported " + fileName)
        dft.currentTime = dft.currentTime +
dft.timeStepInterval

(18)完整的脚本如图2-24 所示。可以通过查看 C:ArcpyBookcodeCh2TimeEnabledLayers.py解决方案文件来检查代码。


ccaf873b8c8bc45def9cbe6ced5b6dfa3977d0a4

2.12.3 工作原理
DataFrameTime对象可以在数据框中执行时间管理操作。在本节中使用的DataFrameTime属性包括currentTime、startTime、endTime和timeStepInterval等。首先,设置currentTime属性为startTime属性。startTime属性的初始值等于计算出的“Layer Time Extent”属性的起始时间。然后,设置while循环,只要currentTime属性不大于 endTime 属性,则继续循环。在循环体内,创建 fileName 变量存储currentTime属性值与“.pdf”组成的字符串。调用ExportToPDF()函数,传入路径和文件名参数,还可以将布局视图导出为PDF文件。最后,由timeStepInterval属性更新currentTime属性,timeStepInterval属性在属性对话框的“Time Step Interval”属性中设置为“7.0 days”。

相关文章
|
1月前
|
JavaScript 数据挖掘 API
ArcGIS for Python最新编程书籍免费分享
ArcGIS for Python最新编程书籍免费分享
20 0
|
10月前
|
数据可视化 数据管理 API
​​​​​​​ARCGIS API for Python进行城市区域提取
​​​​​​​ARCGIS API for Python进行城市区域提取
​​​​​​​ARCGIS API for Python进行城市区域提取
|
Python
用python偷懒Arcgis(地类编码转地类名称)
在二调中,小班的属性都是用的编码,本文以地类编码为例,如何利用python把代码转化为名称。 excel数据 这里需要整理一份分类系统表的数据,如图: python代码 # -*- coding: utf-8 -*- def getdl(j): import xlrd workbook = xlrd.
1843 0
|
定位技术 Python
《基于ArcGIS的Python编程秘笈(第2版)》——导读
本书将介绍如何使用Python语言来创建桌面ArcGIS环境下的地理处理脚本、工具和快捷方式等。并通过介绍如何使用Python语言和桌面ArcGIS来自动执行地理处理任务、管理地图文档和图层、查找和修复丢失的数据链接、编辑要素类和表中的数据等,以期能够有效地提高GIS工作人员的工作效率。
2952 0
推荐文章
更多