Un modo per farlo è clonare il livello, usando query di definizione ed etichettandole separatamente, usando solo la posizione dell'etichetta in alto a sinistra per il primo livello e in basso a sinistra per il secondo.
Aggiungi il tipo intero THEFIELD al layer e popolalo usando l'espressione seguente:
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
Chiamalo con:
FirstOrOthers( !Shape! )
Crea una copia del livello nella tabella dei contenuti, applica la query di definizione THEFIELD = 1.
Applica la query di definizione THEFIELD = 2 per il livello originale.
Applicare diversi posizionamenti di etichette fisse
AGGIORNAMENTO basato sui commenti alla soluzione originale:
Aggiungi il campo COORD e popolalo usando
'%s %s' %(round( !Shape!.firstPoint.X,2),round( !Shape!.firstPoint.Y,2))
Riassumi questo campo usando first e last per l'etichetta. Unisciti a questa tabella con l'originale usando il campo COORD. Seleziona i record in cui i primi <> ultimi e concatenano la prima e l'ultima etichetta in un nuovo campo usando
'%s\n%s' %(!Sum_Output_4.First_MUID!, !Sum_Output_4.Last_MUID!)
Usa Count_COORD e THEFIELD per definire 2 'diversi livelli' e campi per etichettarli:
Aggiornamento n. 2 ispirato alla soluzione @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 ""
AGGIORNAMENTO Novembre 2016, si spera duri.
Sotto l'espressione testata su 2000 duplicati, funziona come un incantesimo:
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 "