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.
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.