Une transformation
Vous travaillez chez un commissionnaire de transport. Vous recevez donc des commandes de transport de la part de vos clients et votre rôle est d'attribuer ces commandes à des transporteurs.
Un nouveau logiciel a été implanté dans la société pour suivre les commandes en temps réel et on souhaite donc pouvoir comparer les horaires de chargement et de livraison demandés par le client et les horaires réels obtenus grâce au nouveau logiciel. Ceci permettra d'évaluer les différents retards au niveau des usines (retard pour la préparation de la commande par exemple) mais également ceux qui concernent le transporteur (retard à la livraison par exemple).
Vous avez deux fichiers à disposition :
orders.csv
contient l'ensemble des commandes après affrètement, c'est-à-dire qu'il contient l'ensemble des commandes envoyées par le client ainsi que le transporteur que vous avez attribué à chaque commande.Les champs sont les suivants :
OrderNumber : numéro de commande
LoadingPlace : ville de chargement
DeliveryPlace : ville de livraison
Carrier : le transporteur chargé d'effectuer le transport
LoadingDate : date de chargement demandée par le client
ETL (Estimated Time of Loading) : heure de chargement demandée par le client
DeliveryDate : date de livraison demandée par le client
ETA (Estimated Time of Arrival) : heure de livraison demandée par le client
realtime.csv
contient les commandes exploitées dans le logiciel de suivi. On y retrouve donc certaines commandes avec des horaires réels (pas toujours complets).Les champs sont les suivants :
OrderNumber : numéro de commande
RealLoadingDate : date réelle de chargement
RealArrivalAtPlaceOfLoading : heure réelle de chargement
RealDeliveryDate : date réelle de livraison
RealArrivalAtPlaceOfDelivery : heure réelle de livraison
OrderNumber;LoadingPlace;DeliveryPlace;Carrier;LoadingDate;ETL;DeliveryDate;ETA
60055412;Thourotte;Dabrowa;Schade Polska;22-10-2014;10:00;25-10-2014;16:00
60087412;Torgau;Mannheim;Offergeld;10-05-2014;08:00;10-05-2014;18:00
60148965;Pise;Aniche;Lannutti;16-07-2014;06:00;18-07-2014;15:00
60058999;Low Eggborough;Aniche;Campeys of Selby;02-01-2014;16:00;03-01-2014;14:00
60016071;Salaise sur Sanne;Carentan;Transports Elero;03-03-2014;08:00;04-03-2014;10:00
60023562;Dabrowa;Jarozowiesc;ESA Poland;05-08-2014;06:00;06-08-2014;05:00
60056452;Aviles;Arbos;Carcaba;23-09-2014;12:00;23-09-2014;19:00
60023568;Aviles;Thourotte;Glasspartners;15-10-2014;15:00;17-10-2014;13:00
60098745;Aniche;Mannheim;Elbe Torgau Transporte;18-11-2014;09:00;18-11-2014;17:00
60032568;Carentan;Low Eggborough;Avitrans;10-02-2014;11:00;11-02-2014;10:00
60145963;Salaise sur Sanne;Szecin;Offergeld;16-03-2014;09:00;19-03-2014;18:00
60023231;Torgau;Dabrowa;Polonia Logistyka;20-06-2014;10:00;22-06-2014;12:00
60014569;Arbos;Lisbonne;Lannutti; 31-03-2014;06:00;01-04-2014;14:00
60023548;Thourotte;Pise;PKM Logistique;28-02-2014;16:00;02-03-2014;11:00
60025897;Mannheim;Low Eggborough;Campeys of Selby;25-07-2014;11:00;28-07-2014;09:00
OrderNumber;LoadingPlace;DeliveryPlace;Carrier;LoadingDate;ETL;DeliveryDate;ETA 60055412;Thourotte;Dabrowa;Schade Polska;22-10-2014;10:00;25-10-2014;16:00 60087412;Torgau;Mannheim;Offergeld;10-05-2014;08:00;10-05-2014;18:00 60148965;Pise;Aniche;Lannutti;16-07-2014;06:00;18-07-2014;15:00 60058999;Low Eggborough;Aniche;Campeys of Selby;02-01-2014;16:00;03-01-2014;14:00 60016071;Salaise sur Sanne;Carentan;Transports Elero;03-03-2014;08:00;04-03-2014;10:00 60023562;Dabrowa;Jarozowiesc;ESA Poland;05-08-2014;06:00;06-08-2014;05:00 60056452;Aviles;Arbos;Carcaba;23-09-2014;12:00;23-09-2014;19:00 60023568;Aviles;Thourotte;Glasspartners;15-10-2014;15:00;17-10-2014;13:00 60098745;Aniche;Mannheim;Elbe Torgau Transporte;18-11-2014;09:00;18-11-2014;17:00 60032568;Carentan;Low Eggborough;Avitrans;10-02-2014;11:00;11-02-2014;10:00 60145963;Salaise sur Sanne;Szecin;Offergeld;16-03-2014;09:00;19-03-2014;18:00 60023231;Torgau;Dabrowa;Polonia Logistyka;20-06-2014;10:00;22-06-2014;12:00 60014569;Arbos;Lisbonne;Lannutti; 31-03-2014;06:00;01-04-2014;14:00 60023548;Thourotte;Pise;PKM Logistique;28-02-2014;16:00;02-03-2014;11:00 60025897;Mannheim;Low Eggborough;Campeys of Selby;25-07-2014;11:00;28-07-2014;09:00
OrderNumber;RealLoadingDate;RealArrivalAtPlaceOfLoading;RealDeliveryDate;RealArrivalAtPlaceOfDelivery
60055412;22-10-2014;10:45;25-10-2014;
60087412;10-05-2014;07:05;10-05-2014;18:30
60148965;;06:02;18-07-2014;14:00
60016071;04-03-2014;06:00;05-03-2014;11:25
60023562;05-08-2014;14:00;06-08-2014;11:30
60056452;;11:55;23-09-2014;19:05
60023568;15-10-2014;15:00;17-10-2014;16:00
60098745;18-11-2014;;18-11-2014;16:42
60032568;;;;
60145963;15-03-2014;19:50;19-03-2014;16:20
60023231;20-06-2014;09:00;;12:03
60014569;;;;
60023548;28-02-2014;16:00;02-03-2014;11:00
OrderNumber;RealLoadingDate;RealArrivalAtPlaceOfLoading;RealDeliveryDate;RealArrivalAtPlaceOfDelivery 60055412;22-10-2014;10:45;25-10-2014; 60087412;10-05-2014;07:05;10-05-2014;18:30 60148965;;06:02;18-07-2014;14:00 60016071;04-03-2014;06:00;05-03-2014;11:25 60023562;05-08-2014;14:00;06-08-2014;11:30 60056452;;11:55;23-09-2014;19:05 60023568;15-10-2014;15:00;17-10-2014;16:00 60098745;18-11-2014;;18-11-2014;16:42 60032568;;;; 60145963;15-03-2014;19:50;19-03-2014;16:20 60023231;20-06-2014;09:00;;12:03 60014569;;;; 60023548;28-02-2014;16:00;02-03-2014;11:00
On veut procéder à la jointure des deux fichiers CSV. Pour cela, nous devons procéder en deux étapes car une jointure nécessite d'avoir trié les données au préalable.
Question
Créez une nouvelle transformation :
Fichier > Nouveau > Transformation
La transformation, nommée par défaut
Transformation 1
apparaît alors dans l'ongletNavigateur
Enregistrer
Sélectionner le répertoire dans lequel vous souhaitez enregistrer votre fichier et renommer la transformation si vous le souhaitez
Un fichier nomTransformation.ktr a été créé dans le répertoire que vous avez désigné.
Question
Pour l'analyse future de nos données, l'entreprise a souhaité que les horaires manquants soient considérés comme une "vraie" information.
Cela veut dire qu'on ne veut pas de valeurs nulles dans notre table mais plutôt une information du type "données inconnues" lorsqu'il manque une date ou un horaire.
Question
La modélisation de votre transformation est maintenant terminée et vous devriez avoir le résultat suivant :
