Définition des schémas de conversion (ecedi5115s000)

Cette session permet d'enregistrer les champs, la séquence et les options pour la conversion des messages entrants.

Remarque

Cette session est protégée afin d'éviter toute interférence provenant de sessions s'exécutant simultanément.

Organisation

Code qui représente le jeu de normes (ANSI X12, UN/EDIFACT et VDA) utilisé dans les communications EDI.

Description

Description ou nom du code.

Message EDI

Messages entrants et/ou sortants pris en charge par l'application. Ces messages peuvent être actifs (c'est-à-dire utilisés dans la société) ou non.

Description

Description ou nom du code.

Direction

Direction du message EDI.

Type du champ

Format de fichier ASCII.

Note: 

Il est possible de créer un schéma de conversion pour les fichiers dont les champs sont de longueur fixe ou séparés par un séparateur de champ.

Code Schéma de conversion

Code qui identifie le schéma de conversion.

Description

Description ou nom du code.

Destination

Source du champ d'un message sortant définie dans la session Schémas de conversion (Relations) (ecedi5112m000).

Champ

Nom du champ, par exemple, tdsls400.ofbp. Pour les schémas de conversion sortants, vous pouvez également utiliser des constantes. Les constantes doivent commencer par des guillemets ("). Tout texte entre guillemets est inséré dans le message.

Note: 

Si vous souhaitez employer des guillemets à l'intérieur d'une chaîne de texte, vous devez saisir des guillemets supplémentaires. Par exemple, pour obtenir "ABC", vous devez saisir ""ABC"".

Champ

Description ou nom du code.

Numéro de séquence

Numéro de séquence du champ. Un même champ peut être inclus plusieurs fois. Si le champ n'apparaît qu'une seule fois dans les schémas de conversion, vous pouvez lui donner la valeur 0 ou 1. S'il y apparaît plusieurs fois, son numéro de séquence doit être incrémenté d'une unité pour chaque occurrence dans la définition de schéma de conversion.

Séquence de traitement

Séquence dans laquelle le champ sera traité.

Niveau

Niveau défini dans la session Schémas de conversion (Relations) (ecedi5112m000).

Description

Description ou nom du code.

Position de début

Position du champ dans la ligne.

Note: 

Si le champ Type de champ de la session Réseaux (ecedi0120s000) contient Longueur fixe, vous devez saisir sa position de départ physique. Si le champ Type de champ de la session Réseaux (ecedi0120s000) contient Délimité, vous devez saisir le numéro de champ, en commençant par le numéro 1.

Elément

Elément d'index pour un champ d'index ou position de début dans une variable de chaîne.

Exemple de champ d'index

Dans le cas d'une variable de chaîne, la position de début de la chaîne peut être précisée. Ce champ, combiné au champ Longueur, permet d'indiquer une sous-chaîne (par exemple : pour la chaîne "ABCDEFGHIJKLMNOP", la valeur 3 avec une longueur de 5 produit la chaîne suivante : "CDEFG").

Champ tdsls400.disc (profondeur standard = 5 niveaux)
Niveau 1 10
  2 15
  3 8
  4 5
  5 7

Lorsque la valeur est 0, le champ s'affiche en entier : 010015008005007. Cette option ne peut être utilisée que pour les communications internes. Les valeurs 1 et 3 ne produisent que les éléments suivants : 010 et 008. Ce résultat signifie que le champ peut également être utilisé pour les communications externes.

Longueur

Longueur physique du champ.

Lecture de l'enregistrement suivant

Si cette case est cochée, un nouvel enregistrement sera lu à ce niveau pour les messages entrants et un nouvel enregistrement de la table appartenant au champ sera lu pour les messages sortants. Si cette case n'est pas cochée, les nouveaux enregistrements ne seront pas lus, mais les enregistrements courants resteront actifs.

Note: 

Ce champ indique si un nouvel enregistrement doit être lu afin de traiter le contenu du champ. Selon la valeur de ce champ, vous pouvez déterminer si une nouvelle ligne est prête à être lue à partir du même fichier.

Niveau itératif

Numéro de séquence indiquant l'endroit où le curseur doit être déplacé après le traitement du champ. Ce champ n'est utilisé que si l'enregistrement est destiné au dernier champ d'un niveau interactif ou au dernier champ d'un schéma de conversion.

Exemple

Par exemple : Vous souhaitez saisir un champ de texte contenant les données d'un fichier ASCII dans un en-tête de commande, qui est traité de façon itérative. Une fois le dernier champ de texte saisi, le curseur revient au champ dont le numéro de séquence est 3 par l'intermédiaire du champ Numéro de séquence. La clé et les trois champs de texte sont inclus dans chaque ligne de niveau 2.

Champ Niveau Numéro de séquence Niveau itératif
N° d'ordre 1 1  
Référence 1 2  
Champ de texte 2 3  
Champ de texte 2 4  
Champ de texte 2 5 3
La clé ne correspond pas

Numéro de séquence qui indique l'emplacement où le curseur doit être déplacé si la clé est incorrecte ou si celle-ci a changé. Ce champ n'a besoin d'être renseigné que si le nouvel enregistrement est Oui.

Exemple 1 - Traitement itératif

Une fois que tous les champs ont été traités, le numéro de client est lu. Le niveau 2 est itératif.

Champ Niveau Séquence dans Retour Retour Nouveau
Itér. Enregistrement clé        
N° d'ordre 1 1      
Référence 1 2      
Champ de texte 2 3   6 oui
Champ de texte 2 4      
Champ de texte 2 5 3    
Client 1 6      

Exemple 2 - Traitement séquentiel

Une fois toutes les lignes de la commande remplies (niveau 2), une nouvelle commande peut être introduite (niveau 1).

Champ Niveau Séquence dans Retour Retour Nouveau
Itér. Enregistrement clé        
N° d'ordre 1 1     oui
Référence 1 2      
Client 1 3      
Article 2 4   1 oui
Quantité 2 5      
Date de livraison 2 6 4    
Ecrire l'enregistrement

Si cette case est cochée,, une fois qu'un champ de message entrant a été traité, un enregistrement doit être ajouté à la table concernée selon le résultat de l'expression de sortie. La destination du champ (titre, en-tête ou ligne) détermine la table dans laquelle les messages sont enregistrés.

Exemple 1

Champ Destination Ecrire l'enregistrement
N° d'ordre en-tête  
Référence en-tête  
Client en-tête oui
Article ligne  
Quantité ligne  
Date de livraison ligne oui

Les champs traités après une session d'écriture pour la même destination ne sont pas ajoutés à la table appropriée. Vous ne pouvez pas démarrer plusieurs sessions d'écriture pour un même enregistrement (par exemple : une ligne de commande). En raison de la hiérarchie des destinations, LN vérifie si toutes les destinations supérieures ont été écrites ou non. Si la destination supérieure n'a pas été écrite, les destinations concernées seront enregistrées avant la destination indiquée. La hiérarchie est la suivante :

  • Titre
  • En-tête
  • Ligne

Exemple 2

Champ Destination Ecrire l'enregistrement
N° d'ordre en-tête  
Référence en-tête  
Client en-tête  
Article ligne  
Quantité ligne  
Date de livraison ligne oui

Comme l'en-tête n'a encore été écrit, celui-ci est écrit en premier, suivi de la ligne. S'il n'y a pas de titre, la ligne est écrite avant l'en-tête.

Evaluation

Code de l'expression d'évaluation. Cette expression détermine si le champ doit être inclus ou non dans le message. Il s'agit d'une expression logique dont le résultat est vrai ou faux. La valeur par défaut de ce champ est 1, vrai. L'expression est exécutée avant l'insertion du champ dans le message. Autrement dit, les actions de lecture et d'écriture associées sont toujours exécutées. En fait, l'expression est une équation. Par exemple, pour le champ Magasin de la commande fournisseur, l'expression peut être : strip((tdpur400.cwar) <> "" Cette expression est vraie si le champ Magasin n'est pas renseigné.

Le tableau suivant répertorie les opérateurs par ordre de priorité :

  • ()
  • - (signe moins)
  • * / \
  • &
  • + - (ajouter soustraire)
  • = > < <> <= >=
  • NOT
  • AND
  • OR
  • ?:

Une expression peut contenir les constantes suivantes :

PI 3.1415926535..
TRUE Toujours vrai.
FALSE Toujours faux.

Une expression peut contenir des fonctions.

Il est également possible d'utiliser des plages numériques : a IN [10,20] est égal à .a>=20 AND a<=30 a IN [10,20][30,40][50,60] est égal à a>=10 AND a<=20 OR a>=30 AND a<=40 OR a>=50 AND a<=60

Exemple arithmétique

() parenthèses (priorité)  
- signe négatif (argument requis) a=-b
* multiplication 3*5=15
/ division 6/2=3
\ reste d'une division 8\3=2
& concaténation de chaînes "A"&"B"="AB"
+ addition 2+3=5
- soustraction 3-2=1

Relations (pour comparaison) Exemple

= ou EQ est égal à 3=5 est faux
<> ou NE est différent de 3<>5 est vrai
> ou NE est supérieur à 3>5 est faux
< ou LT est inférieur à 3<5 est vrai
>= ou GE est supérieur ou égal à 3>=5 est faux
<= ou LE est inférieur ou égal à 3<=5 est vrai

Exemple logique

AND et (les deux sont vrais) a=b AND b=c
OR ou (l'un des deux est vrai) a=b OR a=c
NOT non (n'est pas vrai) NOT (a=b AND b=c)

Autres :

condition?vrai:faux si <condition> est vraie, <vrai> est exécuté, sinon <faux> (toujours entourer les <condition> de parenthèses car elles ont la priorité la plus basse)

Fonctions

abs(N) Produit la valeur absolue de N
acos(N) Produit l'angle (en radians) dont N est le cosinus.
asc(S) Produit le total des valeurs ASCII des caractères de S, asc("ABC")=65+66+67=198
asin(N) Produit l'angle (en radians) dont N est le sinus.
atan(N) Produit l'angle (en radians) dont N est la tangente.
chr(N) Produit le caractère dont N est la valeur ASCII, chr(65)="A"
cos(N) Produit le cosinus de l'angle N (en radians).
cosh(N) Produit le cosinus hyperbolique de l'angle N (en radians).
date() Produit le numéro du jour courant.
date(J,M,D) Produit le numéro du jour dans la date représentée par J, M et A.
exp(N) Produit 2.718128. à la puissance N.
int(N) Produit l'entier de N (arrondi à l'unité inférieure).
len(S) Produit le nombre de caractères de S, len("ABC")=3.
log(N) Produit le logarithme naturel de N.
log10(N) Produit le logarithme en base 10 de N.
max(N,M) Produit la valeur la plus élevée de N ou M.
min(N,M) Produit la valeur la moins élevée de N ou M.
pos(S,T) Produit la première position où T apparaît dans S, pos("ABCDEFEF","EF")=5.
pow(N,M) Elève N à la puissance M.
round(N,D,M) Produit la valeur de N arrondie à D décimales. Si M=0, N est arrondi à l'unité inférieure, round(1.99,2,0)=1.00. If M=1, N est arrondi normalement, round(1.49,2,1)=1.00 et round(1.50,2,1)=2.00. Si M=2, N est arrondi à l'unité supérieure, round(1.01,2,2)=2.00.
rpos(S,T) Produit la dernière position où T apparaît dans S, rpos("ABCDEFEF,"EF")=7.
sin(N) Produit le sinus de l'angle N (en radians).
sinh(N) Produit le sinus hyperbolique de l'angle N (en radians).
sqrt(N) Produit la racine carrée non négative de N.
str(N) Crée une chaîne de N, str(1.04)="1.04"
strip(S) Ramène S à la ligne sans les espace qui le suivent.
tan(N) Produit la tangente de l'angle N (en radians).
tanh(N) Produit la tangente hyperbolique de l'angle N (en radians).
time() Produit l'heure courante au format HHMM format.
val(S) Produit la valeur numérique de S, val("1.04")=1.04.
Description

Description ou nom du code.

Affectation

Code pour l'expression d'assignation. Le résultat de l'expression est écrit dans le fichier ASCII (messages sortants), qui est mis à jour dans l'application LN (messages entrants). Par exemple, pour conférer à la Date de livraison planifiée une valeur antérieure de deux jours à la Date de réception planifiée, vous devez attribuer l'expression d'assignation suivante au champ Date de livraison planifiée: tdsls400.prdt - 2.

Note: 

Tous les champs de table référencés dans une expression d'assignation doivent être traités avant le champ auquel cette expression d'assignation est attribuée. Le champ référencé dans l'expression d'assignation doit avoir une séquence de traitement inférieure, comme indiqué dans les définitions de schéma de conversion. Par exemple, dans l'exemple précédent, le champ tdsls400.prdt doit avoir une séquence de traitement inférieure au champ tdsls400.ddat, comme indiqué dans les définitions de schéma de conversion.

Table de conversion

Table de conversion utilisée pour convertir le champ.

Action si table de conversion introuvable

Marche à suivre si une erreur est signalée lors de la conversion des messages sortants. Une erreur peut se produire lorsque le champ est introuvable dans la table de conversion.

Note: 

La valeur sélectionnée doit pouvoir être prise en charge par les sessions de traitement.

Segments de texte

Nombre maximum de segments de texte d'un champ de texte.

Note: 

Les textes d'un message ont une structure particulière qui nécessite un traitement distinct. Chaque texte consiste en un certain nombre de segments, chacun composé d'un certain nombre de champs.

Nombre maximum de champs texte par segment texte

Nombre maximum de champs dans un segment de texte.

Note: 

Les textes d'un message ont une structure particulière qui nécessite un traitement distinct. Chaque texte consiste en un certain nombre de segments, chacun composé d'un certain nombre de champs.

Code de position de début

Position de départ du premier qualificateur. Certaines conversions de code dans ERP EDI nécessitent un identificateur de code. Ces ID sont des qualificateurs utilisés dans les conversions de code pour vous permettre de convertir des spécifications de données supplémentaires et sont transférées à la première position de qualificateur des définitions de schémas de conversion.

Note: 

Si le champ Type de champ de la session Réseaux (ecedi0120s000) contient Longueur fixe, vous devez saisir sa position de départ physique. Si le champ Type de champ de la session Réseaux (ecedi0120s000) contient Délimité, vous devez saisir le numéro de champ, en commençant par le numéro 1.

Longueur du code

Longueur physique du qualificateur.

Note: 

Cette valeur ne peut être saisie que si le type de champ est Longueur fixe, tel qu'il a été défini dans la session Paramètres EDI (ecedi0100s000).

Paramètres par défaut

Valeur à utiliser si aucun qualificateur n'est utilisé dans le message.

Note: 

Si vous choisissez de convertir les articles sortants au moyen de la table Codes Article par système de codage, vous pouvez saisir la valeur du champ Système de codage ici. Vous pouvez vous servir de la table des ID codes Article pour convertir la valeur de ce qualificateur en la valeur utilisée dans le message. Vous pouvez remplacer la valeur saisie ici en renseignant le champ Système de codage de la session Messages EDI pris en charge par tiers (ecedi0111s000).

Table de conversion

Table de conversion utilisée pour convertir le qualificateur.

Action si table de conversion introuvable

Marche à suivre si une erreur est signalée lors de la conversion des messages sortants. Il arrive qu'une erreur se produise, due au fait que le qualificateur soit introuvable dans la table de conversion.

Champ

Informations de conversion pour ce champ descriptif et l'élément de données correspondant du message EDI. Ce champ descriptif n'est utilisé qu'à titre d'information et de référence.

Code 1

Informations de conversion pour le premier qualificateur et l'élément de données correspondant du message EDI.

Code 2

Informations de conversion pour le second qualificateur et l'élément de données correspondant du message EDI.