Compiler l'intersection (Analyse)

Synthèse

Calcule l’intersection entre deux classes d’entités et génère un tableau croisé des surfaces, longueurs ou nombre d'entités d’intersection.

Illustration

Illustration de l'outil Tabuler l'intersection

Utilisation

  • Une zone se compose de toutes les entités du paramètre Entités de zone en entrée pour lesquelles les valeurs du paramètre Champs de zone sont identiques. De même, une classe est composée de toutes les entités du paramètre Entités de classe en entrée pour lesquelles les valeurs du paramètre Champs de classe sont identiques. Il n’est pas nécessaire que les entités soient contiguës pour être dans la même zone ou classe. Cet outil permet de calculer la portion de la zone qui est intersectée par chaque classe (surface et pourcentage de surface de zone).

  • Si aucune valeur de Champs de classe n'est spécifiée, toutes les entités du paramètre Entités de classe en entrée sont considérées comme une classe unique. La valeur Table en sortie contient un enregistrement pour chaque zone.

  • Lorsqu’une valeur Champs de classe est spécifiée, la valeur Table en sortie contient n enregistrements pour chaque zone, n représentant le nombre de classes dans cette zone. Par exemple, si une zone contient quatre classes, la valeur Table en sortie comprendra quatre enregistrements pour cette zone.

  • Les attributs numériques du paramètre Entités de classe en entrée peuvent être additionnés par zone à l'aide du paramètre Champs de somme. La somme des valeurs d’une classe représente une proportion de la somme des valeurs en fonction du pourcentage de la classe qui présente une intersection avec la zone.

    Attention :

    Utilisez les champs contenant des valeurs absolues (et non des valeurs relatives normalisées, telles que des pourcentages ou des densités) en tant que Champs de somme car les valeurs peuvent être fractionnées et réparties dans différentes zones.

  • La dimension des valeurs des Entités de classe en entrée ne peut pas être supérieure à celle des valeurs des Entités de zone en entrée.

    • Si les valeurs des Entités de zone en entrée sont des points, les valeurs des Entités de classe en entrée ne peuvent pas être des polygones ou des lignes.
    • Si les valeurs des Entités de zone en entrée sont des lignes, les valeurs des Entités de classe en entrée ne peuvent pas être des polygones.

  • Lorsque les valeurs des Entités de zone en entrée et des Entités de classe en entrée sont des polygones, les statistiques de la table en sortie sont basées sur les calculs de la surface.

    Lorsque les valeurs des Entités de classe en entrée sont des lignes, les statistiques de la table en sortie sont basées sur des calculs linéaires.

    Lorsque les valeurs des Entités de classe en entrée sont des points, les statistiques de la table en sortie sont basées sur le nombre d'entités.

  • Si les valeurs des Entités de zone en entrée et des Entités de classe en entrée possèdent la même dimension (toutes deux sont des entités surfaciques, linéaires ou ponctuelles), le champ PERCENTAGE en sortie enregistre le pourcentage de l’entité de zone qui est intersectée par la classe.

    Si les valeurs des Entités de zone en entrée et des Entités de classe en entrée possèdent des dimensions différentes (zone de polygone avec classe linéaire, zone de polygone avec classe de points ou zone de ligne avec une classe de points), le champ PERCENTAGE en sortie enregistre le pourcentage de la classe qui intersecte le polygone de zone.

    Le champ PERCENTAGE peut enregistrer une valeur de pourcentage supérieure à 100 en présence d'entités superposées dans les Entités de zone en entrée ou les paramètres Entités de classe en entrée.

  • Le champ AREA est inclus dans la table en sortie uniquement lorsque les valeurs des Entités de zone en entrée et des Entités de classe en entrée sont des polygones. Le champ AREA contient la superficie des valeurs des Entités de zone en entrée intersectées par les valeurs des Entités de classe en entrée.

    Un champ LENGTH est inclus dans la table en sortie lorsque les valeurs des Entités de classe en entrée sont des lignes. Le champ LENGTH contient la longueur de l'intersection entre les valeurs des Entités de zone en entrée et des Entités de classe en entrée.

    Un champ PNT_COUNT est inclus dans la table en sortie lorsque les valeurs des Entités de classe en entrée sont des points. Le champ PNT_COUNT contient le nombre de points des Entités de classe en entrée qui intersectent les valeurs des Entités de zone en entrée.

  • Lors de l'utilisation de couches d'entités, si des entités sont sélectionnées, seules les entités sélectionnées sont utilisées dans les calculs.

  • La détermination de l'intersection des entités de classe et de zone suit les mêmes règles que l'outil Intersecter.

  • Utilisez l’outil Table croisée pour transformer la valeur de la Table en sortie en une table qui contient un enregistrement pour chaque zone avec des attributs de classe comme champs attributaires distincts. Renseignez les paramètres de l'outil Table croisée comme suit :

    • Table en entrée - Compiler l'intersection Table en sortie
    • Champs en entrée - Tabuler l'intersection Champs de zone
    • Champ de croisement - Compiler l'intersection Champs de classe
    • Champ de valeur - Compiler l'intersection Champs de somme ou AREA, LENGTH, PERCENTAGE
    Exemple de table croisée en sortie

Paramètres

ÉtiquetteExplicationType de données
Entités zones en entrée

Entités permettant d'identifier des zones.

Feature Layer
Champs de zone

Le ou les champs attributaires utilisés pour définir les zones.

Field
Entités de classement en entrée

Entités permettant d'identifier des classes.

Feature Layer
Table en sortie

Table contenant la tabulation croisée des intersections entre zones et classes.

Table
Champs de classe
(Facultatif)

Le ou les champs attributaires utilisés pour définir les classes.

Field
Champs de somme
(Facultatif)

Les champs à additionner à partir du paramètre Entités de classe en entrée.

Field
Tolérance XY
(Facultatif)

Distance qui détermine la plage dans laquelle les entités ou leurs sommets sont considérés comme identiques. Par défaut, il s'agit de la tolérance XY du paramètre Entités de zone en entrée.

Attention :

Modifier la valeur de ce paramètre peut provoquer des erreurs ou des résultats inattendus. Il est recommandé de ne pas modifier ce paramètre. Ce paramètre n’est plus affiché dans la boîte de dialogue de l’outil. Par défaut, la propriété Tolérance x,y de la référence spatiale de la classe d’entités en entrée est utilisée.

Linear Unit
Unités en sortie
(Facultatif)

Spécifie les unités à utiliser pour les calculs de surface ou de longueur. Il est impossible de définir les unités en sortie lorsque les entités de classe en entrée sont des points.

  • InconnuLes unités ne seront pas connues.
  • PoucesLes unités seront les pouces.
  • PiedsL’unité sera le pied.
  • YardsLes unités sontseront les yards.
  • MilesL'unité sera le mile.
  • Milles nautiquesL’unité sera le mille nautique.
  • MillimètresLes unités seront les millimètres.
  • CentimètresLes unités seront les centimètres.
  • DécimètresLes unités seront les décimètres.
  • MètresL’unité sera le mètre.
  • KilomètresL’unité sera le kilomètre
  • Degrés décimauxL’unité sera le degré décimal.
  • PointsLes unités sont les points.
  • AresLes unités sont les ares.
  • AcresLes unités seront les acres.
  • HectaresLes unités seront les hectares.
  • Pouces carrésLes unités seront les pouces carrés.
  • Pieds carrésLes unités seront les pieds carrés.
  • Yards carrésLes unités seront les yards carrés.
  • Miles carrésLes unités seront les miles carrés.
  • Millimètres carrésLes unités seront les millimètres carrés.
  • Centimètres carrésLes unités seront les centimètres carrés.
  • Décimètres carrésLes unités seront les décimètres carrés.
  • Mètres carrésLes unités seront les mètres carrés.
  • Kilomètres carrésLes unités seront les kilomètres carrés.
String

arcpy.analysis.TabulateIntersection(in_zone_features, zone_fields, in_class_features, out_table, {class_fields}, {sum_fields}, {xy_tolerance}, {out_units})
NomExplicationType de données
in_zone_features

Entités permettant d'identifier des zones.

Feature Layer
zone_fields
[zone_fields,...]

Le ou les champs attributaires utilisés pour définir les zones.

Field
in_class_features

Entités permettant d'identifier des classes.

Feature Layer
out_table

Table contenant la tabulation croisée des intersections entre zones et classes.

Table
class_fields
[class_fields,...]
(Facultatif)

Le ou les champs attributaires utilisés pour définir les classes.

Field
sum_fields
[sum_fields,...]
(Facultatif)

Les champs à additionner à partir du paramètre in_class_features.

Field
xy_tolerance
(Facultatif)

Distance qui détermine la plage dans laquelle les entités ou leurs sommets sont considérés comme identiques. Par défaut, il s'agit de la tolérance XY du paramètre in_zone_features.

Attention :

Modifier la valeur de ce paramètre peut provoquer des erreurs ou des résultats inattendus. Il est recommandé de ne pas modifier ce paramètre. Ce paramètre n’est plus affiché dans la boîte de dialogue de l’outil. Par défaut, la propriété Tolérance x,y de la référence spatiale de la classe d’entités en entrée est utilisée.

Linear Unit
out_units
(Facultatif)

Spécifie les unités à utiliser pour les calculs de surface ou de longueur. Il est impossible de définir les unités en sortie lorsque les entités de classe en entrée sont des points.

  • UNKNOWNLes unités ne seront pas connues.
  • INCHESLes unités seront les pouces.
  • FEETL’unité sera le pied.
  • YARDSLes unités sontseront les yards.
  • MILESL'unité sera le mile.
  • NAUTICAL_MILESL’unité sera le mille nautique.
  • MILLIMETERSLes unités seront les millimètres.
  • CENTIMETERSLes unités seront les centimètres.
  • DECIMETERSLes unités seront les décimètres.
  • METERSL’unité sera le mètre.
  • KILOMETERSL’unité sera le kilomètre
  • DECIMAL_DEGREESL’unité sera le degré décimal.
  • POINTSLes unités sont les points.
  • ARESLes unités sont les ares.
  • ACRESLes unités seront les acres.
  • HECTARESLes unités seront les hectares.
  • SQUARE_INCHESLes unités seront les pouces carrés.
  • SQUARE_FEETLes unités seront les pieds carrés.
  • SQUARE_YARDSLes unités seront les yards carrés.
  • SQUARE_MILESLes unités seront les miles carrés.
  • SQUARE_MILLIMETERSLes unités seront les millimètres carrés.
  • SQUARE_CENTIMETERSLes unités seront les centimètres carrés.
  • SQUARE_DECIMETERSLes unités seront les décimètres carrés.
  • SQUARE_METERSLes unités seront les mètres carrés.
  • SQUARE_KILOMETERSLes unités seront les kilomètres carrés.
String

Exemple de code

1er exemple d'utilisation de la fonction TabulateIntersection (fenêtre Python)

Utilisez la fonction TabulateIntersection dans la fenêtre Python pour trouver la superficie de chaque type de végétation dans chaque zone.

import arcpy
arcpy.analysis.TabulateIntersection("Zones", "zone_id", "Vegetation", 
                                    r"C:\Esri\veganalysis.gdb\vegtypeAreas", 
                                    "VEGTYPE")
2ème exemple d'utilisation de la fonction TabulateIntersection (script autonome)

Ce script encapsule la fonction TabulateIntersection afin de créer un outil de script TabulateArea simple. L'outil de script TabulateArea utilise seulement des entités surfaciques en entrée.

Les champs Zone et Classe sont respectivement limités à un.

'''
TabulateArea.py
Description: Shows how to wrap the TabulateIntersection tool to create a TabulateArea script tool
Requirements: Polygon Zone Feature Class, Polygon Class Feature Class

'''
import arcpy
import sys
import os

def AddMsgAndPrint(msg, severity=0):
    # Adds a Message (in case this is run as a tool)
    # and also prints the message to the screen (standard output)
    print(msg)

    # Split the message on \n first, so that if it's multiple lines, 
    # a GPMessage will be added for each line
    try:
        for string in msg.split('\n'):
            # Add appropriate geoprocessing message 
            if severity == 0:
                arcpy.AddMessage(string)
            elif severity == 1:
                arcpy.AddWarning(string)
            elif severity == 2:
                arcpy.AddError(string)
    except:
        pass

## Get Parameters
zoneFC = arcpy.GetParameterAsText(0)
zoneFld = arcpy.GetParameterAsText(1) # Only allow one field
classFC = arcpy.GetParameterAsText(2)
outTab = arcpy.GetParameterAsText(3)
classFld = arcpy.GetParameterAsText(4) # Optional and only allow one field
sum_Fields = ""
xy_tol = ""
outUnits = arcpy.GetParameterAsText(5)

## Validate parameters
# Inputs can only be polygons
zoneDesc = arcpy.Describe(zoneFC)
classDesc = arcpy.Describe(classFC)
if zoneDesc.shapeType != "Polygon" or classDesc.shapeType != "Polygon":
    AddMsgAndPrint("Inputs must be of type polygon.", 2)
    sys.exit()
    
# Only one zone field and class field
if zoneFld != "":
    if zoneFld.find(";") > -1 or classFld.find(";") > -1:
        AddMsgAndPrint("A maximum of one zone and/or class field is allowed.", 2)
        sys.exit()

# Run TabulateIntersection
try:
    arcpy.analysis.TabulateIntersection(zoneFC, zoneFld, classFC, outTab, 
                                        classFld, sum_Fields, xy_tol, outUnits)
except:
    arcpy.AddMessage("Tabulate Intersection Failed.")

AddMsgAndPrint(arcpy.GetMessages(), 0)

Informations de licence

  • Basic: Non
  • Standard: Non
  • Advanced: Oui

Rubriques connexes