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 :

Lecture de fichier Excel sur Mac


Sujet :

MATLAB

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2014
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Transports

    Informations forums :
    Inscription : Février 2014
    Messages : 30
    Par défaut Lecture de fichier Excel sur Mac
    Salut,
    J'aurais un grand besoin de votre aide:
    Je suis en possession d'un fichier excel avec dans la 1ere colonne des chiffres variant de 0 à 6. Il faudrait que, grâce à mon code MatLab, je crée un nouveau fichier avec les mêmes informations mais en enlevant les lignes où la 1ere colonne contient un 0 ou un 6.
    Je ne sais pas pourquoi mon code MatLab ne fonctionne pas, j'ai l'impression que mon textscan ne marche pas bien...
    Ci-dessous mon code:

    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
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    fidWrite = fopen('radar291NPLvoie123JO.log', 'w+');
    fid = fopen('DonneesAgregees/radar291NPLvoie123.xls');
     
    beta=textscan(fid,'%d %s %d %d %d %f %f %f %f %d %f %f %f %f');
    index=1;
    total_size=length(beta{1,1})
     
    current_date=0;
    last_hour=0;
    cars_count=0;
    speed_average=0.0;
    headway_average=0.0;
    timeGap_average=0.0;
    length_average=0.0;
    flow=0;
    flow1=0.0;
    flow2=0.0;
    flow3=0.0;
    density=0.0;
     
    while (index<=total_size)
     
        if (1<=beta{1,1,1}<=5)
    current_date=beta{1,2,1}(index);
    last_hour=beta{1,4,1}(index);
    cars_count=beta{1,5,1}(index);
    speed_average=beta{1,6,1}(index);
    headway_average=beta{1,7,1}(index);
    timeGap_average=beta{1,8,1}(index);
    length_average=beta{1,9,1}(index);
    flow=beta{1,10,1}(index);
    flow1=beta{1,11,1}(index);
    flow2=beta{1,12,1}(index);
    flow3=beta{1,13,1}(index);
    density=beta{1,14,1}(index);
        end
     
        fprintf(fidWrite,'%s %d %d %f %f %f %f %d %f %f %f %f\n',current_date,last_hour,cars_count,speed_average,headway_average,timeGap_average,length_average,flow,flow1,flow2,flow3,density);
     
        index=index+1;
    end
     
    fclose(fid);
    fclose(fidWrite);
    Et mon fichier excel de base: Essai2.xlsx

  2. #2
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 317
    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 317
    Par défaut
    Pourquoi ne pas utiliser xlsread pour lire le fichier Excel ?

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2014
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Transports

    Informations forums :
    Inscription : Février 2014
    Messages : 30
    Par défaut
    Merci pour ton aide je vais essayer comme ca!

  4. #4
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2014
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Transports

    Informations forums :
    Inscription : Février 2014
    Messages : 30
    Par défaut
    Excuse moi mais je n'arrive pas à utiliser xlsread et xlswrite:
    Dans mon code je remplace fidWrite et fid par:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    beta=xlsread('radar291NPLvoie123JO.log');
    A la fin je remplace fprintf par:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    filename = 'radar291NPLvoie123JO.xls';
    A = [current_date, last_hour,...]
    xlswrite(filename,A)
    Cela m'indique une erreur quand je lance le code directement

    De plus, ma deuxième colonne de mon fichier de base contient des formats dates sur excel que je veux recopier dans un format similaire sur mon nouveau fichier excel. Comment puis-je faire ça?
    Merci beaucoup de votre aide


    De plus ma deuxième

  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 317
    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 317
    Par défaut
    Tes explications sont assez incompréhensibles.

    Dans un premier temps tu parles d'un fichier .xls puis maintenant d'un fichier .log ?

    Ensuite, tu te doutes bien qu'il serait utile de nous donner le message d'erreur complet.

  6. #6
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2014
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Transports

    Informations forums :
    Inscription : Février 2014
    Messages : 30
    Par défaut
    Je suis désolé, je réexplique en ayant clarifié mon code:

    Le but: Avec un fichier excel comme envoyé dans mon premier message, il faut que je le traite sur MatLab pour avoir un nouveau fichier final avec le "current_date, last_hour, cars_count_d1" des lignes ayant dans la première colonne comme chiffre: 1,2,3,4,5 (de l'ancien fichier).
    Mes questions: current_date est au format date sur excel cela pose-t-il un pb? last_hour est un int mais cars_count_d1 un float, comment retourner dans le fichier avec les bons formats?

    Enfin et le plus important: mon code (ci-joint en dessous) affiche cela en message d'erreur:

    Warning: Could not start Excel server for import, 'basic' mode will be used.
    Refer to HELP XLSREAD for more information. 
    > In xlsread at 174
      In traitement2 at 9 
    Error using xlsread (line 217)
    XLSREAD unable to open file radar291NPL123.xls.
    File /Users/cypriensay/Documents/MATLAB/ProjetBis/radar291NPL123.xls not found.
    
    Error in traitement2 (line 9)
    xlsread('radar291NPL123.xls');
    Mon code est:

    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
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
     
     
    function [ ] = traitement2( )
    tic
    %TEST Summary of this function goes here
    %   Detailed explanation goes here
     
     
    beta=xlsread('radar291NPL123.xls');
    index=1;
    total_size=length(beta);
     
    current_date=0;
    last_hour=0;
    cars_count_d1=0;
     
     
     
    while (index<=total_size)
     
        if (1<=beta(index,1)<=5)
    current_date=beta(index,2);
    last_hour=beta(index,4);
    cars_count_d1=beta(index,5);
     
        end
     
        filename = 'radar291NPLvoie123JO.xls';
        A = [current_date, last_hour, cars_count_d1]
        xlswrite(filename,A)
        index=index+1;
    end
     
    toc
    Merci beaucoup et désolé de mes explications peu claires...

Discussions similaires

  1. Conversion fichier Excel vers fichier PDF sur Mac
    Par Invité dans le forum Documents
    Réponses: 19
    Dernier message: 19/02/2015, 14h57
  2. Réponses: 6
    Dernier message: 27/03/2012, 15h58
  3. {VBA Excel}Question sur la lecture de fichier excel
    Par Thomas69 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 11/12/2007, 09h12
  4. Peut on importer un fichier excel sur sage 500
    Par tedy75 dans le forum Excel
    Réponses: 3
    Dernier message: 11/02/2006, 19h18
  5. Problème de lecture de fichier Excel
    Par cocaetjusdorange dans le forum Langage
    Réponses: 4
    Dernier message: 08/02/2006, 11h08

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