Résumé
Joint des attributs d’une couche à une autre en fonction de relations spatiales, temporelles ou attributaires, ou d’une combinaison de ces relations.
Illustration
Utilisation
Une jointure spatiale apparie les entités (lignes) à partir des entités en entrée (Target Layer (Couche cible) et Joint Layer (Couche de jointure)) en fonction de leurs localisations géographiques. Une jointure temporelle apparie les entités (lignes) à partir des entités en entrée en fonction de leurs relations temporelles. Une jointure attributaire apparie les entités en fonction des valeurs figurant dans des champs.
Vous pouvez joindre des entités selon une relation spatiale, temporelle ou attributaire, ou une combinaison des trois.
options Description Spatial Relationship (Relation spatiale)
Relation spatiale qui va déterminer si les entités sont jointes les unes aux autres. Les relations disponibles dépendent du type de géométrie (point, ligne ou surface) des couches jointes. Les relations spatiales disponibles sont les suivantes :
- Intersecte
- Est égal à
- Planar Near (Planaire à proximité) : utilise les distances planaires.
- Geodesic Near (Proche géodésique) : utilise les distances géodésiques. Cette option est disponible uniquement avec ArcGIS Enterprise 10.7.1 et version ultérieure.
- Contient
- Dans
- Touche
- Croise
- Superpose
En savoir plus sur les relations spatiales dans les outils GeoAnalytics Server
Temporal Relationship (Relation temporelle)
Relation temporelle qui va déterminer si les entités sont jointes les unes aux autres. Les relations disponibles dépendent du type de temps (instant ou intervalle) des couches jointes. Les relations temporelles disponibles sont les suivantes :
- Rejoint
- Rejoint par
- Superpose
- Superposé par
- Pendant
- Contient
- Est égal à
- Termine
- Terminé par
- Démarre
- Démarré par
- Intersecte
- Proche
- À proximité avant
- À proximité après
En savoir plus sur les relations temporelles dans les outils GeoAnalytics Server
Attribute Relationship (Relation attributaire)
Relation attributaire qui va déterminer si les entités sont jointes les unes aux autres. Les entités sont appariées lorsque les valeurs de champ de la couche de jointure sont identiques à celles de la couche cible.
Si les entités cible et de jointure se trouvent dans des systèmes de coordonnées différents, le système de coordonnées de l’entité cible est utilisé. Si un système de coordonnées en sortie est spécifié, les deux entités sont projetées dans le système de coordonnées en sortie, puis elles sont jointes.
Lorsque la valeur du paramètre Spatial Relationship (Relation spatiale) est Planar near (Proche plan), l’outil Join Features (Joindre les entités) exige la projection de la valeur Target Layer (Couche cible) ou le paramétrage du système de coordonnées en sortie sur un système de coordonnées projetées.
Si plusieurs entités correspondent à la même entité cible, vous pouvez choisir si toutes les entités appariées sont jointes (Join one to many [Joindre un à plusieurs]) ou si toutes les entités appariées sont synthétisées ensemble (Join one to one [Joindre un à un]) comme suit :
- Join one to many (Joindre un à plusieurs) : joint toutes les entités d’appariement de la couche de jointure à la couche cible. La couche de résultat contiendra plusieurs enregistrements de l’entité cible.
- Join one to one (Joindre un à un) : synthétise toutes les entités de jointure appariées à chaque entité de la couche cible. Seules les entités appariées seront incluses dans la synthèse et la sortie. Le nombre d’entités jointes sera ajouté, en plus d’autres statistiques, telles que somme, minimum, maximum, plage, moyenne, variance et écart type. Par défaut, seules les entités cible ayant les relations spécifiées sont conservées dans la classe d’entités en sortie (jointure interne). Si l’option Keep All Target Features (Conserver toutes les entités cible) est activée, toutes les entités cible en entrée sont écrites dans la classe d’entités en sortie (jointure externe conservée).
Vous pouvez éventuellement générer une expression pour joindre des entités à l’aide du paramètre Join Condition (Condition de jointure). Si vous spécifiez une expression, seules les entités qui remplissent la condition sont utilisées. Par exemple, à l’aide de l’expression $target["Magnitude"] > $join["Explosion"], vous pouvez seulement joindre des entités cible du champ Magnitude si elles sont supérieures à l’entité de jointure du champ Explosion. Pour plus d'informations, reportez-vous à la rubrique Expressions pour joindre les entités.
Les champs suivants sont inclus dans les entités en sortie lorsque vous réalisez une jointure un à plusieurs :
- Tous les champs des couches cible
- Tous les champs de la couche de jointure
Si le même nom de champ existe dans le jeu de données cible et le jeu de données de jointure, le champ de jointure commence par le mot joint (par exemple, join_fieldname).
Nom du champ Description start_datetime
Ce champ représente l’heure de début et est créé lorsque l’entrée possède une composante temporelle (instant ou intervalle).
end_datetime
Ce champ représente l’heure de fin et est créé lorsque l’entrée possède une composante temporelle de type intervalle.
Outre les champs issus de la couche cible, les champs suivants sont inclus dans les entités en sortie lorsque vous réalisez une jointure un à un :
Nom du champ Description count
Nombre d’entités qui ont été jointes.
statistic_fieldname
Les statistiques indiquées créent chacune un champ attributaire nommé selon le format suivant : statistic_fieldname. Par exemple, l’écart maximal et l’écart type du champ id sont MAX_id et SD_id.
start_datetime
Ce champ représente l’heure de début et est créé lorsque l’entrée possède une composante temporelle (instant ou intervalle).
end_datetime
Ce champ représente l’heure de fin et est créé lorsque l’entrée possède une composante temporelle de type intervalle.
Vous pouvez améliorer les performances de l’outil Reconstruire les pistes en suivant les conseils ci-après :
- Définissez l’environnement de l’étendue de manière à analyser uniquement des données d’intérêt.
- Utilisez la méthode planaire au lieu de la méthode géodésique.
- N’appliquez pas de zone tampon.
- Fractionnez vos pistes à l’aide des paramètres Time Split (Fraction temporelle), Time Boundary Split (Limite de fraction temporelle), Distance Split (Fraction spatiale) ou Split Expression (Expression de fractionnement). Le paramètre Time Boundary Split (Limite de fraction temporelle) permet d’obtenir les meilleures performances.
- Utilisez les données locales de l’environnement de l’analyse.
L’analyse de similarité peut également être réalisée à l’aide de l’outil Jointure spatiale de la boîte à outils Analyse.
Cet outil de géotraitement est mis en œuvre par ArcGIS GeoAnalytics Server. L’analyse est réalisée sur le GeoAnalytics Server et les résultats sont stockés dans votre contenu dans ArcGIS Enterprise.
Lors de l’exécution des outils GeoAnalytics Server, l’analyse est réalisée sur GeoAnalytics Server. Pour des performances optimales, GeoAnalytics Server doit pouvoir accéder aux données via les couches d’entités hébergées sur votre portail ArcGIS Enterprise ou les partages de fichiers Big Data. Les données qui ne sont pas locales pour GeoAnalytics Server sont transférées sur GeoAnalytics Server avant le début de l’analyse. Autrement dit, l’exécution d’un outil prend plus de temps et, dans certains cas, le transfert des données entre ArcGIS Pro et GeoAnalytics Server peut échouer. Le seuil d’échec dépend aussi bien des débits du réseau que de la taille et de la complexité des données. Il est par conséquent recommandé de toujours partager les données ou créer un partage de fichiers Big Data.
Pour en savoir plus sur le partage des données dans votre portail.
Pour en savoir pus sur la création d'un partage de fichiers Big Data via ArcGIS Server Manager
Syntaxe
arcpy.geoanalytics.JoinFeatures(target_layer, join_layer, output_name, join_operation, {spatial_relationship}, {spatial_near_distance}, {temporal_relationship}, {temporal_near_distance}, {attribute_relationship}, {summary_fields}, {join_condition}, {data_store}, {keep_all_target_features})
Paramètre | Explication | Type de données |
target_layer | Cliquez sur les entités cible. Les attributs provenant des entités cible et ceux des entités jointes sont transférés à la sortie. | Record Set |
join_layer | Contient les entités de jointure. Les attributs des entités jointes sont joints aux attributs des entités cible. Reportez-vous à l’explication du paramètre Join Operation (Opération de jointure) (join_operation dans Python) pour en savoir plus sur les répercussions du type d’opération de jointure sur l’agrégation des attributs joints. | Record Set |
output_name | String | |
join_operation | Indique le mode de traitement des jointures entre les valeurs target_layer et les valeurs join_layer dans l’entité en sortie, si plusieurs entités de jointure présentent une relation spatiale identique avec une même entité cible.
| String |
spatial_relationship (Facultatif) | Spécifie les critères utilisés pour joindre spatialement les entités.
| String |
spatial_near_distance (Facultatif) |
Distance par rapport à une entité cible pour laquelle les entités de jointure sont prises en compte dans le cadre de la jointure spatiale. Un rayon de recherche est valide uniquement lorsque la valeur du paramètre spatial_relationship est NEAR ou NEAR_GEODESIC. | Linear Unit |
temporal_relationship (Facultatif) | Spécifie les critères temporels utilisés pour apparier les entités.
Spécifie les critères temporels utilisés pour apparier les entités.
| String |
temporal_near_distance (Facultatif) |
Distance dans le temps par rapport à une entité cible pour laquelle les entités de jointure sont prises en compte dans le cadre de la jointure spatiale. Des données temporelles sont valides uniquement lorsque la valeur du paramètre temporal_relationship est défini sur NEAR, NEAR_BEFORE ou NEAR_AFTER et que les deux entités sont temporelles. | Time Unit |
attribute_relationship [attribute_relationship,...] (Facultatif) | Joint les entités en fonction des valeurs figurant dans un champ attributaire. Spécifiez le champ attributaire de la couche cible qui doit correspondre à un champ attributaire de la couche de jointure.
| Value Table |
summary_fields [summary_fields,...] (Facultatif) | Statistiques qui seront calculées sur les champs spécifiés.
| Value Table |
join_condition (Facultatif) | Applique une condition à des champs spécifiés. Seules les entités comprenant des champs remplissant ces conditions seront jointes. Par exemple, vous pouvez appliquer une condition de jointure à des entités lorsque l’attribut HealthSpending (Dépenses de santé) de la couche de jointure est supérieur à 20 % de l’attribut Income (Revenus) de la couche cible. Dans les versions 10.5 et 10.5.1, la condition de jointure à utiliser pour appliquer cette expression est join["HealthSpending"] > target["Income"] * .2. Dans la version 10.6 ou une version ultérieure, utilisez une expression Arcade telle que $join["HealthSpending"] > $target["Income"] * .2. | String |
data_store (Facultatif) | Indique le ArcGIS Data Store dans laquelle la sortie est enregistrée. La valeur par défaut est SPATIOTEMPORAL_DATA_STORE. Tous les résultats stockés dans un répertoire de données Big Data spatio-temporelles seront stockés en WGS84. Les résultats stockés dans un répertoire de données relationnelles conservent leur système de coordonnées.
| String |
keep_all_target_features (Facultatif) | Spécifie si toutes les entités cible sont conservées dans la classe d’entités en sortie (jointure externe conservée), ou uniquement celles ayant les relations spécifiées avec les entités jointes (jointure interne).
| Boolean |
Sortie dérivée
Nom | Explication | Type de données |
output | Sortie jointe. | Jeu d'enregistrements |
Exemple de code
Le script autonome suivant illustre l'utilisation de l'outil JoinFeatures.
# Name: JoinFeatures.py
# Description: Join crime events that are close together in time and space, and
# return the count of nearby crimes. This example is a self join
# (joining the same layer to itself).
# Requirements: ArcGIS GeoAnalytics Server
# Import system modules
import arcpy
# Set local variables
inFeatures = "https://MyGeoAnalyticsMachine.domain.com/geoanalytics/rest/services/DataStoreCatalogs/bigDataFileShares_Crimes/BigDataCatalogServer/Chicago"
spatialOperation = "NEAR"
nearDistance = "1 Kilometers"
temporalOperation = "NEAR"
nearTime = "3 Hours"
outFS = "CloseCrimes"
dataStore = "SPATIOTEMPORAL_DATA_STORE"
# Execute Join Features
arcpy.geoanalytics.JoinFeatures(inFeatures, inFeatures, outFS, "JOIN_ONE_TO_ONE",
spatialOperation, nearDistance, temporalOperation,
nearTime, None, None, None, dataStore)
Environnements
- Système de coordonnées en sortie
Système de coordonnées qui sera utilisé pour l'analyse. L’analyse sera réalisée dans le système de coordonnées en entrée, à moins que ce paramètre en spécifie un autre. Pour les Outils GeoAnalytics, les résultats finaux seront stockés dans le stockage des données spatio-temporelles dans WGS84.
Informations de licence
- Basic: Requiert ArcGIS GeoAnalytics Server
- Standard: Requiert ArcGIS GeoAnalytics Server
- Advanced: Requiert ArcGIS GeoAnalytics Server
Rubriques connexes
Vous avez un commentaire à formuler concernant cette rubrique ?