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

Développement Office System .NET Discussion :

[Microsoft.Office.Interop.Excel] Parcourir un gros fichier anormalement lent


Sujet :

Développement Office System .NET

  1. #1
    Membre éclairé

    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    1 085
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 085
    Points : 886
    Points
    886
    Par défaut [Microsoft.Office.Interop.Excel] Parcourir un gros fichier anormalement lent
    Bonjour à tous,

    Je possède Office365 et je dois importer un fichier Excel assez imposant provenant d'un fournisseur (+- 90.000 lignes sur 15 colonnes).
    En fait, nous recevons tous les jours ce fichier qui jusqu'à il y a une semaine, s'importait sans trop de problème via une machine avec Win7 + Office 2003

    Maintenant elle est passée en Windows 10 et Office 365.
    A chaque itération pour récupérer la valeur d'une cellule, ça prend +- 2 sec. Faites le compte avec toutes les cellules (15*90 000 * 2)...

    J'ai passé pas mal de temps sur Google et essayé beaucoup de reconfiguration d'excel mais ça ne change rien. (Désactivation accélération matérielle, désactivation animation, etc.)

    Avez-vous déjà eu le cas ? Avez-vous trouvé une solution ?

    PS: Comportement assez cocasse , Lors de l'itération, si j'affiche l'instance Excel et que je bouge ma souris sur le document, ça va plus vite.
    Si je clique sur le titre du document Excel et que je laisse le clic enfoncé, ça va encore plus vite.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application();            xlApp.Visible = true;
                Microsoft.Office.Interop.Excel.Workbook xlWorkbook = xlApp.Workbooks.Open(@"d:\Test.xlsx");
                Microsoft.Office.Interop.Excel._Worksheet xlWorksheet = xlWorkbook.Sheets[1];
     
                string c = "";
                int count = xlWorksheet.Cells.Find("*", System.Reflection.Missing.Value,
                                   System.Reflection.Missing.Value, System.Reflection.Missing.Value,
                                   Microsoft.Office.Interop.Excel.XlSearchOrder.xlByRows, Microsoft.Office.Interop.Excel.XlSearchDirection.xlPrevious,
                                   false, System.Reflection.Missing.Value, System.Reflection.Missing.Value).Row;
     
     
                for (int i = 1;  i <= count-1; i++)
                {
                    c = xlWorksheet.Cells[i, 1].Text;
                    button1.Text = i.ToString();
                    button1.Refresh();
                }
    Merci d'avance pour votre aide

  2. #2
    Membre éprouvé Avatar de WDKyle
    Homme Profil pro
    Analyste-Programmeur
    Inscrit en
    Septembre 2008
    Messages
    1 200
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste-Programmeur

    Informations forums :
    Inscription : Septembre 2008
    Messages : 1 200
    Points : 962
    Points
    962
    Par défaut
    Bonjour,

    Quel est le but de ce code ? Je vois un Cell.Find(), tu fais des recherches...?

    Sinon ce qui est gourmand c'est l'affichage et l'actualisation de l'IHM d'Excel. Regarde les méthodes Visible, ScreenUpdating et EnableEvents.

  3. #3
    Membre éclairé

    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    1 085
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 085
    Points : 886
    Points
    886
    Par défaut
    Bonjour,

    Non le but de ce code n'est qu'à titre d'exemple

    Là où c'est gourmand, c'est la partie Get Value d'une cellule => xlWorksheet.Cells[i, 1].Text
    Je me demande maintenant si ce n'est pas le document qui est pourri... Quand j'exporte le résultat en CSV puis du CSV en XLSX, c'est rapide...

    Je pense que je vais clôturer ce post car j'ai l'impression que ce problème n'est pas très répandu et qu'il n'a peut être pas de solution hormis celle que je propose.

    Merci quand même

  4. #4
    Inactif  

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2012
    Messages
    4 904
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4 904
    Points : 10 168
    Points
    10 168
    Billets dans le blog
    36
    À ma connaissance, le seul personnage qui a été diagnostiqué comme étant allergique au mot effort. c'est Gaston Lagaffe.

    Ô Saint Excel, Grand Dieu de l'Inutile.

    Excel n'a jamais été, n'est pas et ne sera jamais un SGBD, c'est pour cela que Excel s'appelle Excel et ne s'appelle pas Access junior.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Lister les fichiers Excel ouverts avec Microsoft.Office.Interop.Excel
    Par datacell33 dans le forum Général Dotnet
    Réponses: 2
    Dernier message: 19/10/2010, 10h41
  2. Réponses: 5
    Dernier message: 21/05/2009, 23h59
  3. [C#] Microsoft.Office.Interop.Excel Range
    Par User.Anonymous dans le forum C#
    Réponses: 8
    Dernier message: 23/11/2007, 14h58
  4. Réponses: 2
    Dernier message: 25/06/2007, 20h31
  5. Réponses: 4
    Dernier message: 21/05/2007, 18h23

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