IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Dotnet Discussion :

Thread : une tache longue


Sujet :

Dotnet

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2017
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2017
    Messages : 58
    Points : 45
    Points
    45
    Par défaut Thread : une tache longue
    Bonsoir,

    je suis entrain de réaliser une application de rapprochement de deux fichiers excel (plus de 1200 lignes )
    j'ai fait un programme séquentielle mais je vois qu'il prend beaucoup de temps a exécuter
    j'ai essayé d'utiliser les threads mais ça pose des problèmes.

    y-a-t-il une autre méthode pour réduire le temps d'exécution ?

    Merci d'avance les amis .

  2. #2
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut
    ca dépend déjà de ce que tu utilises pour lire ou écrire dans les fichiers excel
    l'interop c'est lent, si les fichiers ont une ligne d'entete tu peux utiliser oledb, c'est très performant

    sinon tu peux peut etre paralléliser (parallel.foreach par exemple)
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2017
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2017
    Messages : 58
    Points : 45
    Points
    45
    Par défaut
    oui en effet j'utilise interop et j'ai réfléchi d'utiliser le parallélisme mais quand même le programme prend beaucoup de temps(plus de 20 min
    et ça me dérange :/ )
    j'ai pas un identifiant unique dans mes fichiers ,je dois construire un a partir de deux champs

  4. #4
    Membre régulier
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2013
    Messages
    51
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2013
    Messages : 51
    Points : 72
    Points
    72
    Par défaut
    Tu es obligé de travailler avec Excel ? Tu devrais plutôt travailler avec du csv (donc du texte délimité) en utilisant Linq.

  5. #5
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2017
    Messages
    58
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2017
    Messages : 58
    Points : 45
    Points
    45
    Par défaut
    Citation Envoyé par dzediar Voir le message
    Tu es obligé de travailler avec Excel ? Tu devrais plutôt travailler avec du csv (donc du texte délimité) en utilisant Linq.
    Oui je suis obligé de travailler sur des fichiers excel

  6. #6
    Expert éminent sénior

    Avatar de François DORIN
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2016
    Messages
    2 757
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2016
    Messages : 2 757
    Points : 10 697
    Points
    10 697
    Billets dans le blog
    21
    Par défaut
    Bonjour,

    Tout d'abord, il serait bon que tu nous montre ton code, histoire de voir ce qui ne va pas. Car 20min pour du rapprochement de données (1200 lignes) ça me parait tout simplement énorme !

    Maintenant, tu es obligé de travaillé avec des fichiers Excel. Soit. Mais peux être peux-tu passer par autre chose que de l'interop pour accéder aux données. Par exemple, si les fichiers sont des fichiers OOXML, alors tu peux utiliser une bilbliothèque comme EPPLUS pour accéder à tes données. L'avantage, c'est qu'en plus d'être rapide et léger, cela ne nécessite pas d'avoir Excel d'installer pour fonctionner.
    François DORIN
    Consultant informatique : conception, modélisation, développement (C#/.Net et SQL Server)
    Site internet | Profils Viadéo & LinkedIn
    ---------
    Page de cours : fdorin.developpez.com
    ---------
    N'oubliez pas de consulter la FAQ C# ainsi que les cours et tutoriels

Discussions similaires

  1. [Thread] Lancer un thread et executer une tache
    Par jeanjean6 dans le forum Débuter avec Java
    Réponses: 4
    Dernier message: 27/05/2010, 14h53
  2. [Swing][Thread] affichage fenetre pdt tache longue
    Par rems033 dans le forum AWT/Swing
    Réponses: 2
    Dernier message: 09/08/2007, 14h39
  3. Réponses: 11
    Dernier message: 24/11/2006, 22h30
  4. Créer une tache planifié (.bat ou wsh)
    Par BRAUKRIS dans le forum Windows
    Réponses: 4
    Dernier message: 18/03/2004, 17h12
  5. [JSP] Ajout d'une tache dans le planificateur Windows
    Par PhoneKilleR dans le forum Servlets/JSP
    Réponses: 6
    Dernier message: 12/09/2003, 15h10

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo