Préparer, intégrer ou exporter un fichier d’écritures (Accounting Entry)

De Guide utilisateur des messages comptables UN/XML

Le but de l’intégration est de préparer une version XML des écritures comptables enregistrées dans la base de données de votre applicatif comptable et de permettre la réception de ces mêmes écritures comptables au format XML.

Analyse des modèles de données

De façon plus générale, il est plus simple de préparer la transmission des écritures comptables que de gérer la lecture d’écritures produites par ailleurs. Il vaut donc mieux commencer par l'écriture ou l'export de données.

Après vous être familiariser avec la syntaxe XML et les composants disponibles, la deuxième étape est d’analyser le modèle de données normalisé. Concentrez-vous, dans un premier temps, sur les données essentielles : une écriture réduite à sa plus simple expression (débit/crédit, date, montant, numéro de compte, numéro de pièce).

En pratique, on distingue trois types de champs :

  • les champs pour lesquels la correspondance est évidente (par exemple, le numéro de compte posera peu de problèmes) ;
  • les champs sur lesquels vous hésitez, il faut les vérifier avec plusieurs jeux de données de tests. Je vous invite à hésiter autant que possible et à vérifier le maximum de données. L'imagination a des limites que les services informatiques aiment à repousser… ;
  • les champs pour lesquels la correspondance n'est pas évidente. Il faut alors se renseigner auprès d’un spécialiste métier et vérifier l’analyse avec plusieurs jeux de données de tests.

Défis lors de l'analyse

L'analyse des données requiert un dialogue constant avec l’analyste ou une personne qualifiée sur le modèle de données. Prévoyez au minimum une demi-journée de disponibilité d'un interlocuteur qualifié.

Veillez également à vous aider d’une sélection représentative de bases de données de tests. Préférez des bases réelles, avec des données terrains : en pratique il y a souvent un écart entre la vision théorique des données et les informations réellement saisies par les utilisateurs. Il ou elle risque donc parfois de vous induire en erreur. D’où l’intérêt de disposer d’un certain nombre de bases de référence. Le dialogue suivant n'est pas rare :

  • "La date de passage de l’écriture se trouve toujours dans le champ FNBCD4."
  • "Tiens dans cette base de données exemple, le champ est vide."
  • "Ah bon ? Laissez-moi voir… effectivement. Je vais me renseigner."
(plus tard)
"Après vérification, effectivement, nous avons prévu un traitement particulier pour les opérations de reprise. Dans ce cas-là, on n'encode pas la date du bon de l’écriture si c'est la date du jour. Il faudrait alors consulter le champs FNDSD4."
  • "D'accord, la date est toujours dans un de ces deux champs ?"
  • "Oui."

Je vous laisse imaginer la suite du dialogue quand vous découvrirez le champs FNDSD4 vide…

Résultats de l'analyse

Au terme de l'analyse, vous disposez d'une table de conversion. Pour la plupart des champs, la mise en commun est évidente. Pour quelques champs, des règles plus compliquées s'appliquent. Quatre cas sont possibles :

  • la donnée est présente directement dans la base (dans l'exemple, c'est le cas du numéro de compte). Ce sera le cas pour la plupart des données ;
  • la donnée n'est pas présente dans la base mais il s'agit d'une constante. Dans l'exemple, c'est le cas de l’heure pour la date/heure de valeur. Si le logiciel utilisé n’enregistre que la date, il faudra fixer l’heure à une valeur conventionnelle ;
  • la donnée n'est pas directement dans la base mais il est possible de la calculer. Par exemple, le numéro de ligne ;
  • la donnée n'est pas dans la base, n'est pas une donnée fixe et il n'est pas possible de la calculer. Dans ce cas-ci, trois cas de figure sont envisageables :
    • dans la plupart des cas, la donnée est facultative en ebXML, ne la renseignez pas
    • sinon il faut prévoir un écran de saisie pour permettre à l’utilisateur de saisir la donnée lors de la préparation du fichier d’export ;
    • s’il n’est pas possible de la faire saisir la donnée (par exemple, parce qu’elle est d’une nature telle qu’elle ne doit pas être modifiée par un utilisateur). Dans ce cas, il n'est pas possible d’exporter en ebXML sans une lourde modification du logiciel. Ce cas est très rare.


Note : il est parfois possible de se ramener à un des cas précédents. Par exemple, en établissant une liste de valeurs fixes, comme une liste de produits.

Pour être complet, notons qu'il est parfois nécessaire de reformater des données, même si elles sont présentes dans la base. Par exemple, les dates ont rarement le bon format.

Exemple de table d'analyse

A titre d'exemple, voici un extrait d’une table de conversion fictive (les noms des champs dans la base de données ont été inventés pour les besoins de l'exemple). Pour des raisons de place, la table de conversion complète n'est pas reproduite mais cette table illustre les cas les plus intéressants :

XML Base de données Commentaires
ram:ID PieceExt
ram:Comment Libelle pas de champs directement équivalente à celui de la base donc on le stocke dans un champ plus générique
ram:ValueDateDateTime DateEnr seule la date est enrégistrée dans la base, l’heure non disponible,
on la fixe conventionnellement à minuit
ram:DebitCreditCode CreditDebit booléen, à transformer en codes 29 ou 30
ram:LineNumeric auto-incrément
ram:LocalAccountingCurrencyAmount Montant
ram:BookingBookedAccountingAccount/ram:ID NumCompte

J’attire votre attention sur les deux premières lignes :

  • ram:ID dans le document XML, PieceExt dans la base de données… rien dans les noms ne permet de faire le rapprochement entre les données. C’est le travail de l’analyste ;
  • de même entre ram:Comment et Libelle la relation n’est pas immédiate.
A priori le libellé corresponds à une information plus spécifique qu’un commentaire mais comme il n’y a pas de champs “label” en ebXML, on se rabat sur un champs à la signification plus générique.

Notez également la dernière ligne, l’élément ram:ID placé plus bas dans la hiérarchie correspond à un autre champs de la base de données.

D'un point de vue pratique, j'aime à annoter directement la description du fichier mais il vous est loisible de travailler avec un tableau ou tout autre format qui vous convienne. Prenez soin de conserver la documentation, elle sera utile pour la maintenance et les corrections.

Comme pour toute analyse, il convient de garder en tête qu'elle permet de traiter les cas les plus fréquents mais qu'un certain nombre d'aspects n'apparaîtront qu'aux tests ! Et le risque est d'autant plus grand si votre base de données ou votre modèle de données est riche ou est en service depuis longtemps.

Une fois l'analyse terminée, on peut passer à la mise en œuvre à l’aide des composants identifiés préalablement.

Tests d’export

On commence par l’export, qui est plus simple puisqu’on a une bonne connaissance des données a traiter.

Les tests se font d'abord en local. Il suffit de produire quelques fichiers XML à partir de plusieurs bases comptables (si possible, essayez d'obtenir des bases comptables réelles couvrant une longue période pour tester le maximum de cas d'erreur).

Vous pouvez tester vos fichiers en les validant par rapport au schéma XML. N'oubliez pas que le schéma ne permet qu'une validation formelle (vérifier si le champs ID est présent, est de la bonne longueur, etc.) mais ne permet pas une validation logique (est-ce que le champ ID contient vraiment un identifiant). Il est utile de vérifier quelques documents dans un éditeur de texte pour faire cette validation logique.

Conservez tous les bases de données collectées pour ces tests. Après une mise à jour, refaites un test avec tous ces bases de données.

N'oubliez pas : il est plus facile de corriger un problème lors du développement (quand vous avez toutes les données fraîchement en tête) que par la suite donc testez aussi complètement que possible.

Import d'un fichier d'écritures

Le point de départ est l’analyse, vous pouvez ré-utiliser l’analyse précédente. L’import pose trois difficultés supplémentaires :

  • vous ne pouvez pas être certain de la correction des données ;
  • d’autres logiciels appliquent d’autres contrôles. Des données qui sont valides pour le logiciel qui a produit l’export peuvent ne pas être valide pour vous (notamment du à la longueur des champs), vous devez gérez ces différences ;
  • vous devrez définir une stratégie de ré-import, voir de ré-export.

Le premier problème est simple à traiter : les données à importer peuvent contenir des erreurs, elles doivent donc être validées comme une saisie utilisateur pour vérifier que toutes les données obligatoires sont saisies, que les comptes sont équilibrés, etc. Si possible essayer de réutiliser vos routines de validation existantes pour éviter toute incohérence.

La plupart des logiciels comptables ont déjà prévu un module d’échange (par exemple pour les télédéclarations), vous pouvez vous appuyez sur ces mêmes contrôles. Le deuxième problème est plus complexe. Il prend deux formes :

  • les champs obligatoires vides : un logiciel tiers aura des contrôles de saisie différent. Il se peut que des données obligatoires par rapport à vos contrôles ne soient pas renseignées.
C’est le cas inverse des règles de conversion évoquées pour l’export, la solution est similaire : soit on calcule la donnée manquante, soit on la fixe par constante, soit on interroge l’utilisateur
  • les longueurs de champs : il est fréquent que les données transmises soient trop longue pour votre base de données. Il faut alors appliquer un algorithme de raccourcissement.
Deux solutions : soit la donnée est ignorée. On se souvient que dans le champs date/heure de valeur, on ne stocke que la date. On choisira donc d’ignorer l’heure si elle est renseignée.
Soit la donnée est réduite : par exemple, le numéro de pièce peut-être limité à 13 caractères dans votre base de données, il n’est pas limité dans le fichier ebXML. Comment traiter les comptes plus long ? Il faut établir une table de correspondance pour éviter que deux comptes différents soient importés comme identique.

Ce dernier problème mérite un exemple, tant il est fréquent : supposons que vous recevez les données suivantes : AGC324.345323.32, AGC324.345323.62 et AGC324.345323.35.

Clairement c’est plus de 13 caractères mais il serait dangereux de simplement réduire la longueur de l’identifiant, on obtient AGC324.345323 pour les 3 valeurs bien qu’il s’agisse de trois pièces différentes.

Il faut alors établir une liste de correspondance pour garantir que les numéros générés restent uniques, par exemple : AGC324.345321, AGC324.345322 et AGC324.345323.

Idéalement on stockera cette table de correspondance pour les imports suivants. Seul ce stockage garantit la cohérence des ré-imports dans le temps :

Correspondant NumPieceOriginal NumPieceImportee
AGCD AGC324.345323.32 AGC324.34532A
AGCD AGC324.345323.62 AGC324.34532B
AGCD AGC324.345323.35 AGC324.34532C

De même on pourra utiliser la table lors d’un export à destination de ce correspondant pour rétablir les identifiants d’origine et donc assurer une communication bi-directionnelle parfaite.

Retour au sommaire