Skończyło się na tym, że użyłem odpowiedzi gotchuli , ale bez dochodu, ponieważ generalnie ponownie używam utworzonych uchwytów FC, a zyski są używane raz, a potem odrzucane , łatwiej mi jest czytać i rozumieć, co fcs.append()
się dzieje niż fcs = yield(...)
.
def listFcsInGDB(gdb):
''' list all Feature Classes in a geodatabase, including inside Feature Datasets '''
arcpy.env.workspace = gdb
print 'Processing ', arcpy.env.workspace
fcs = []
for fds in arcpy.ListDatasets('','feature') + ['']:
for fc in arcpy.ListFeatureClasses('','',fds):
#yield os.path.join(fds, fc)
fcs.append(os.path.join(fds, fc))
return fcs
gdb = sys.argv [1]
fcs = listFcsInGDB(gdb)
for fc in fcs:
print fc
Wyniki:
d:\> python list-all-fc.py r:\v5\YT_Canvec.gdb
Processing r:\v5\YT_Canvec.gdb
Buildings_and_structures\BS_2530009_0
Buildings_and_structures\BS_2380009_2
Buildings_and_structures\Tower
Buildings_and_structures\Underground_reservoir
...
To jest teraz w module, który nazywam arcplus *. Wpisz swój drugi kod lub PYTHONPATH, a następnie:
import arcplus
fcs = arcplus.listAllFeatureClasses('d:\default.gdb')
for fc in fcs:
print "magic happens with: ", fc
Arcplus dodaje również filtrowanie symboli wieloznacznych; przetwarzać tylko klasy elementów rozpoczynające się od „HD_” w zestawach danych elementów zawierających „Hydro”
fcs = arcplus.listAllFeatureClasses(gdb, fd_filter='*Hydro*', fc_filter='HD_*')
. * teraz w Github, zaktualizowany do wersji 10.x. Arcgis 9.3 patrz tutaj .
arcpy.da.Walk
) brzmią: Jak sporządzić wykaz GIS?