日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

arcgis批量出图python代码_python使用arcpy.mapping模块批量出图

發布時間:2024/7/23 python 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 arcgis批量出图python代码_python使用arcpy.mapping模块批量出图 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

出圖是項目里常見的任務,有的項目甚至會要上百張圖片,所以批量出土工具很有必要。arcpy.mapping就是ArcGIS里的出圖模塊,能快速完成一個出圖工具。

arcpy.mapping模塊里常用的類有MapDocument、DataFrame、Layer、DataDrivenPages和TextElement。

MapDocument類是地圖文檔(.mxd文件)對應的類。初始化參數是一個字符串,一般是.mxd文件的路徑:

mxd=arcpy.mapping.MapDocument(r"F:\GeoData\ChinaArea\ChinaVector.mxd")

DataFrame類用于操作地圖內的Data Frame(即下圖的Layers),能夠控制地圖的范圍、比例尺等。用arcpy.mapping.ListDataFrames(map_document, {wildcard})函數獲取。

df= arcpy.mapping.ListDataFrames(mxd)[0]

Layer類用于操作具體的圖層。能夠控制圖斑的樣式、可見性等。可以用.lyr文件的路徑初始化,也可以通過arcpy.mapping.ListLayers(map_document_or_layer, {wildcard}, {data_frame})函數獲取。

lyr1=arcpy.mapping.Layer(r" F:\GeoData\ChinaArea\Province.lyr")

df.addLayer(lyr1)

lyr2=arcpy.mapping.ListLayer(mxd,"",df)[0]

DataDrivenPages類需要配合ArcMap中的Data Driven Pages工具使用。用于一個矢量文件內的全部或部分圖斑每個出一張圖的情況。

TextElement類用于操作地圖上的文字,比如圖名、頁數。通過arcpy.mapping.ListLayoutElements (map_document, {element_type}, {wildcard})函數獲取。

txtElm=arcpy.mapping.ListLayoutElements(mxd,"TEXT_ELEMENT")[0]

常見的出圖模式有兩種:一個矢量文件里每個圖斑出一張圖,一個文件夾下每個矢量文件出一張圖。

每個圖斑出一張圖:

這種情況有Data Driven Pages工具配合最好。打開ArcMap的Customize->Toolbars->Data Driven Pages,設置好圖層、名稱字段、排序字段、顯示范圍和比例尺,保存地圖。

# coding:utf-8

import arcpy

mxd=arcpy.mapping.MapDocument(r"F:\GeoData\ChinaArea\ChinaVector.mxd")

for pageNum in range(1,mxd.dataDrivenPages.pageCount):

mxd.dataDrivenPages.currentPageID=pageNum

mapName=mxd.dataDrivenPages.pageRow.getValue(mxd.dataDrivenPages.pageNameField.name)

print mapName

arcpy.mapping.ExportToPNG(mxd,r"F:\GeoData\ChinaArea\Province\\"+mapName+".png")

print 'ok'

一個文件夾下的每個矢量文件出一張圖:

# coding:utf-8

import arcpy

import os

def GetShpfiles(shpdir):

shpfiles=[]

allfiles=os.listdir(shpdir)

for file in allfiles:

if os.path.isfile(file):

if file.endswith('.shp'):

shpfiles.append(file)

else:

shpfiles.extend(GetShpfiles(file))

return shpfiles

allshps=GetShpfiles(r"F:\GeoData\ChinaArea\Province")

mxd=arcpy.mapping.MapDocument(r"F:\GeoData\ChinaArea\ChinaVector.mxd")

lyr=arcpy.mapping.ListLayer(mxd)[0]

for shp in allshps:

paths=os.path.split(shp)

print paths[1]

lyr.replaceDataSource(paths[0],"SHAPEFILE_WORKSPACE",paths[1])

arcpy.mapping.ExportToPNG(mxd,r"F:\GeoData\ChinaArea\Province\\"+paths[1]+".png")

print 'ok'

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持我們。

本文標題: python使用arcpy.mapping模塊批量出圖

本文地址: http://www.cppcns.com/jiaoben/python/181234.html

總結

以上是生活随笔為你收集整理的arcgis批量出图python代码_python使用arcpy.mapping模块批量出图的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。