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

MATLAB Discussion :

action sur les filtres Excel via MATLAB


Sujet :

MATLAB

  1. #1
    Membre actif
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    189
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2013
    Messages : 189
    Points : 242
    Points
    242
    Par défaut action sur les filtres Excel via MATLAB
    bonjour,

    je souhaiterai savoir si il est possible d'agir sur les filtres d'un classeur Excel directement via Matlab.

    Le problème est le suivant : j'ai développé un petit soft, qui lance des simulations puis sauve les résultats dans un .mat pour les données d'entrée, et dans un fichier excel pour ce qui est des données d'entrée (c'est une exigence client, c'est pas super malin mais je ne peux rien y faire). Le soft permet de charger des simulations précédemment effectuées : le fichier Excel s'ouvre (via la fonction xlsread(file,-1)) et l'utilisateur sélectionne la simu qu'il veut visualiser.

    Comme j'ai beaucoup de parametres d'entrée et de simus sauvées, j'ai pourvu l'excel de filtres afin de trouver au plus vite le cas recherché.

    Seulement j'ai une spec client qui me dit :
    -Si deux appels au fichier de sauvegarde sont fait au cours d'une même session d'utilisation, les réglages des filtres sont conservés
    -les filtres sont réinitialisés a la fermeture du soft

    et la je vois pas trop comment faire, étant donné que je ne peux pas vraiment "laisser la main" à l'utilisateur sur le fichier de sauvegarde
    (il ne peut que cliquer sur les filtres et selectionner une simu).

    Est-ce réalisable?

  2. #2
    Membre actif
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    189
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2013
    Messages : 189
    Points : 242
    Points
    242
    Par défaut
    ou, plus simplement, il y-t-il un moyen de lancer des macros Excel via Matlab?

  3. #3
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 53 166
    Points
    53 166
    Par défaut
    Tu peux essayer en utilisant la méthode Run de l'objet Application sous Excel

    Un peu de lecture : Contrôle d'Excel par MATLAB via Automation
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  4. #4
    Membre actif
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    189
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2013
    Messages : 189
    Points : 242
    Points
    242
    Par défaut
    Ok j'ai reussi a bidouiller quelque chose, qui marche mais ne me satisfait pas pleinement


    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
    18
    19
    20
    21
    22
    23
     
    ExcelApp = actxserver('Excel.Application');
     
    % Show window 
    ExcelApp.Visible = 1;
     
    % Open file located in the current folder.
    ExcelApp.Workbooks.Open(fichier);
    while ExcelApp.Visible ==1
    end
     
     
    ExcelApp = actxserver('Excel.Application');
     
    % Show window
    ExcelApp.Visible = 0;
     
    % Open file located in the current folder.
    ExcelApp.Workbooks.Open(fichier);
     
    chargement = ExcelApp.Run('chargement');
    ExcelApp.Quit;
    ExcelApp.release;
    je n'aime pas du tout le
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    while ExcelApp.Visible ==1
    end
    mais c'est la seule solution que j'ai trouvée pour que l'utilisateur ait tout son temps pour actionner autant de filtres qu'il veut puis sélectionne les entrées qu'il veut AVANT que ne s'exécute la macro "chargement", qui permettra a Matlab de récupérer un condensé des données utiles.
    peut-être il y a il un moyen plus propre de faire ça?

    Cette solution est par contre nickel pour rouvrir l'excel et réinitialiser les filtres lors de la fermeture de l'outil matlab :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    ExcelApp = actxserver('Excel.Application');
     
    % Show window (optional).
    ExcelApp.Visible = 0;
     
    % Open file located in the current folder.
    ExcelApp.Workbooks.Open(fichier1);
     
    ExcelApp.Run('TRI');
     
     
    ExcelApp.Quit;
    ExcelApp.release;

  5. #5
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 53 166
    Points
    53 166
    Par défaut
    Tu peux simplement remplacer la boucle while-end par un appel à pause.

    Si tu utilises une interface graphique, tu aussi peux très bien mettre un bouton pour faire exécuter la macro par l'utilisateur quand il le souhaite, non ?
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  6. #6
    Membre actif
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    189
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2013
    Messages : 189
    Points : 242
    Points
    242
    Par défaut
    ok, j'ai mis pause c'est effectivement plus propre

    je ne peux pas utiliser de boutons malgré le fait que j'aie une interface graphique : celle-ci doit être invisible lorsque l'utilisateur se balade sur le fichier excel (spec client a la con...)

    j'ai une autre petite question : peut on détecter si ce fichier a été ouvert par une autre application?

    je pensais faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    wkbk = ExcelApp.ActiveWorkbook;
    et comparer au fichier que je veux ouvrir mais bon il me renvoie []
    y a il un truc du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    wkbk = ExcelApp.OpenWorkbooks
    Après je me dis que ce ne doit même pas être le même objet ExcelApp, et je pense qu 'il faut passer par autre chose, mais je vois pas quoi


    EDIT :

    bon en fait il faut faire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ExcelOuvert = actxGetRunningServer('Excel.Application') ; 
    wkbk = ExcelOuvert.ActiveWorkbook.Name;
    mais la encore, je n'obtiens que le dernier classeur excel activé
    comment passer tous les classeurs excel ouverts en revue?

Discussions similaires

  1. [2012] OpeningPeriod sur les filtres dans excel
    Par Donpi dans le forum SSAS
    Réponses: 0
    Dernier message: 31/03/2015, 09h16
  2. Recupération d'information sur les filtres
    Par Alpha31 dans le forum Access
    Réponses: 2
    Dernier message: 16/06/2006, 22h35
  3. action sur les touches
    Par max---- dans le forum Allegro
    Réponses: 6
    Dernier message: 10/04/2006, 23h42
  4. Aide sur les macros Excel pour recopie auto de données
    Par nicoduhavre dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 15/11/2005, 08h38
  5. [JScrollBar] Récupéré les actions sur les scrollbars
    Par lilou77 dans le forum Agents de placement/Fenêtres
    Réponses: 3
    Dernier message: 20/10/2005, 10h36

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