Skrip Python untuk Membuat Tabel Menggunakan Data Driven Pages


11

Saya mencoba untuk mengkonversi beberapa skrip python untuk menampilkan tabel (berdasarkan dbf) dari fitur yang terletak di dalam halaman data driven tertentu. Sejauh ini, skrip saya berhasil menyegarkan peta ke tabel tertentu, tetapi skrip tidak memperbarui tabel.

Saya memilikinya mengatur sebagai tiga kotak teks yang harus diperbarui dengan tiga bidang spesifik ketika pengguna menjalankan skrip dari ArcToolbox.

Ada saran mengapa meja saya tidak diperbarui?

import arcpy, sys, os

#Reference current MXD
mxd = arcpy.mapping.MapDocument("current")

#Get input parameter
Name = arcpy.GetParameterAsText(0)

#Reference  data frames
mapatlasDF = arcpy.mapping.ListDataFrames(mxd, "Layers")[0]
locatorDF = arcpy.mapping.ListDataFrames(mxd, "Locator Map")[0]

#Reference appropriate layers
atlasLyr = arcpy.mapping.ListLayers(mxd, "PinalCreekMapAtlas_HalfMile", mapatlasDF)[0]
locatorLyr = arcpy.mapping.ListLayers(mxd, "Locator Map", locatorDF)[0]
atlasoutlineLyr = arcpy.mapping.ListLayers(mxd, "Map Atlas Outline", locatorDF)[0]

#Reference layout elements by calling ListLayoutElements 
for elm in arcpy.mapping.ListLayoutElements(mxd):
  if elm.name =="Table1Column1": tab1Col1Txt = elm
  if elm.name =="Table1Column2": tab1Col2Txt = elm
  if elm.name =="Table1Column3": tab1Col3Txt = elm

#Reference the Data Driven Page object
ddp = mxd.dataDrivenPages

#Set the current page to be the one selected in the script tool
arcpy.AddMessage(Name)

pageID = mxd.dataDrivenPages.getPageIDFromName(str(Name))
mxd.dataDrivenPages.currentPageID = pageID

#Set the appropriate definition queries
atlasLyr.definitionQuery = "Name = '" + Name +  "'"
locatorLyr.definitionQuery = "Name = '" + Name +  "'"
atlasoutlineLyr.definitionQuery = "Name <> '" + Name +  "'"

#Update Sheet Index data frame
arcpy.SelectLayerByAttribute_management(locatorLyr, "NEW_SELECTION", "\"Name\" = '" + Name + "'")
locatorDF.panToExtent(locatorLyr.getSelectedExtent())

#Reference Affected Parcels table and select appropriate records
parcelTable = arcpy.mapping.ListTableViews(mxd, "AffectedParcels")[0]

#Build query and create search cursor to loop through rows
parcelFieldValue = "Page " + Name
queryExp = "\"MapPage\" = '" + parcelFieldValue + "'"  #e.g., "MapPage" = 'Page 01'
parcelRows = arcpy.SearchCursor(parcelTable.dataSource, queryExp)

#Clear all table text values
tab1Col1Txt.text = " "; tab1Col2Txt.text = " "; tab1Col3Txt.text = " "

#iteate through each row, update appropiate text
count = 0
for row in parcelRows:
  if count < 30: #Table1 - static position
    tab1Col1Txt.text = tab1Col1Txt.text + row.getValue("OwnerName") +"\n"
    tab1Col2Txt.text = tab1Col2Txt.text + row.getValue("APN") + "\n"
    tab1Col3Txt.text = tab1Col3Txt.text + row.getValue("LengthTrail") + "\n"
  if count ==30:  
    arcpy.AddMessage("Table Overflow") #The code could be reworked to show the last 90 records
  count = count + 1

arcpy.RefreshActiveView()
arcpy.AddMessage("PROCESS COMPLETED")

Saya akan mulai dengan mencoba mengurangi skrip Anda menjadi contoh yang lebih sederhana. Apakah objek dikembalikan berdasarkan ListLayoutElementstipe TextElement? Bisakah Anda memperbarui satu nilai teks dalam skrip, tanpa ada kode lainnya?
scw

seperti kata SCW, apakah elemen sebenarnya dikembalikan? Saya akan menambahkan arcpy.AddMessage ("Ditemukan Table1Column1") di masing-masing statment dan kemudian tambahkan arcpy.AddMessage (tab1Col1Txt.text + tab1Col2Txt.text + tab1Col3Txt.text) di if count <30 area. Ini akan memberikan ide yang lebih baik tentang di mana masalah terjadi.
eseglem

Dari kode tidak jelas di mana objek tab1Col1Txt, tab1Col2Txt dan tab1Col3Txt didefinisikan. Pertama coba verifikasi apa yang dikembalikan oleh bagian row.getValue
Matej

Jawaban:


2

Mungkin contoh-contoh ini dapat membantu:

DDP dengan Tabel dan Grafik Dinamis 10.1_v1

Sampel ini menunjukkan bagaimana API arcpy.mapping digunakan untuk memperluas kemampuan Data Driven Pages (DDP) untuk menghasilkan seri peta yang benar-benar tabel dan grafik yang dinamis

arcpy.mapping Book Map dengan Dynamic Graphic Tables

Proyek ini menggabungkan Data Driven Pages dan arcpy.mapping untuk membangun seri peta yang menyertakan tabel grafik dinamis.


1
Bisakah Anda memberikan lebih banyak konten dalam jawaban Anda? Jawaban hanya tautan tidak disukai karena tautan dapat berubah seiring waktu.
artwork21
Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.