Jednym ze sposobów na to jest klonowanie warstwy, używanie zapytań definicji i etykietowanie ich osobno, przy użyciu pozycji etykiety tylko w lewym górnym rogu dla pierwszej warstwy i lewej dolnej dla drugiej.
Dodaj liczbę całkowitą typu THEFIELD do warstwy i wypełnij ją, używając wyrażenia poniżej:
aList=[]
def FirstOrOthers(shp):
global aList
key='%s%s' %(round(shp.firstPoint.X,3),round(shp.firstPoint.Y,3))
if key in aList:
return 2
aList.append(key)
return 1
Nazwij to:
FirstOrOthers( !Shape! )
Utwórz kopię warstwy w spisie treści, zastosuj zapytanie definicji THEFIELD = 1.
Zastosuj zapytanie definicji THEFIELD = 2 dla oryginalnej warstwy.
Zastosuj inne ustalone położenie etykiety
AKTUALIZACJA na podstawie komentarzy do oryginalnego rozwiązania:
Dodaj pole COORD i wypełnij je, używając
'%s %s' %(round( !Shape!.firstPoint.X,2),round( !Shape!.firstPoint.Y,2))
Podsumuj to pole, używając pierwszego i ostatniego dla etykiety. Dołącz tę tabelę z powrotem do oryginału, używając pola COORD. Wybierz rekordy, w których jodły <> trwają, i połącz pierwszą i ostatnią etykietę w nowym polu za pomocą
'%s\n%s' %(!Sum_Output_4.First_MUID!, !Sum_Output_4.Last_MUID!)
Użyj Count_COORD i THEFIELD, aby zdefiniować 2 „różne warstwy” i pola do ich oznaczenia:
Aktualizacja nr 2 inspirowana rozwiązaniem @Hornbydd:
import arcpy
def FindLabel ([FID],[MUID]):
f,m=int([FID]),[MUID]
mxd = arcpy.mapping.MapDocument("CURRENT")
dFids={}
dLabels={}
lyr = arcpy.mapping.ListLayers(mxd,"centres")[0]
with arcpy.da.SearchCursor(lyr,["FID","SHAPE@","MUID"]) as cursor:
for row in cursor:
FD,shp,LABEL=row
XY='%s %s' %(round(shp.firstPoint.X,2),round( shp.firstPoint.Y,2))
if f == FD:
aKey=XY
try:
L=dFids[XY]
L+=[FD]
dFids[XY]=L
L=dLabels[XY]
L=L+'\n'+LABEL
dLabels[XY]=L
except:
dFids[XY]=[FD]
dLabels[XY]=LABEL
Labels=dLabels[aKey]
Fids=dFids[aKey]
if f == Fids[0]:
return Labels
return ""
AKTUALIZACJA Listopad 2016, mam nadzieję, że będzie trwał.
Poniżej wyrażenia przetestowanego na 2000 duplikatach, działa jak urok:
mxd = arcpy.mapping.MapDocument("CURRENT")
lyr = arcpy.mapping.ListLayers(mxd,"centres")[0]
dFids={}
dLabels={}
fidKeys={}
with arcpy.da.SearchCursor(lyr,["FID","SHAPE@","MUID"]) as cursor:
for FD,shp,LABEL in cursor:
XY='%s %s' %(round(shp.firstPoint.X,2),round( shp.firstPoint.Y,2))
fidKeys[FD]=XY
if XY in dLabels:
dLabels[XY]+=('\n'+LABEL)
dFids[XY]+=[FD]
else:
dLabels[XY]=LABEL
dFids[XY]=[FD]
def FindLabel ([FID]):
f=int([FID])
aKey=fidKeys[f]
Fids=dFids[aKey]
if f == Fids[0]:
return dLabels[aKey]
return "