Una forma de hacer esto es clonando la capa, usando consultas de definición y etiquetándolas por separado, usando la posición de etiqueta superior izquierda para la primera capa y la izquierda inferior para la segunda.
Agregue el entero de tipo THEFIELD a la capa y complételo con la siguiente expresión:
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
Llámalo por:
FirstOrOthers( !Shape! )
Cree una copia de la capa en la tabla de contenido, aplique la consulta de definición THEFIELD = 1.
Aplicar la consulta de definición THEFIELD = 2 para la capa original.
Aplicar diferentes ubicaciones de etiquetas fijas
ACTUALIZACIÓN basada en comentarios a la solución original:
Agregue el campo COORD y complételo usando
'%s %s' %(round( !Shape!.firstPoint.X,2),round( !Shape!.firstPoint.Y,2))
Resuma este campo usando first y last para la etiqueta. Vuelva a unir esta tabla al original usando el campo COORD. Seleccione los registros donde los primeros <> últimos y concatene la primera y la última etiqueta en un campo nuevo usando
'%s\n%s' %(!Sum_Output_4.First_MUID!, !Sum_Output_4.Last_MUID!)
Use Count_COORD y THEFIELD para definir 2 'capas diferentes' y campos para etiquetarlas:
Actualización n. ° 2 inspirada en la solución @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 ""
ACTUALIZACIÓN Noviembre de 2016, es de esperar que dure.
Debajo de la expresión probada en 2000 duplicados, funciona como encanto:
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 "