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 :

enregistrer des fichiers textes dans un tableau de cellules


Sujet :

MATLAB

  1. #21
    Invité
    Invité(e)
    Par défaut
    Je te conseille de bien lire la documentation de la fonction textscan et de bien analyser la structure de ton fichier.
    Citation Envoyé par doc textscan
    %[^...]

    Read only characters not in the brackets, until the first matching character.
    %[^\n] va donc lire indifféremment tous les caractères jusqu'au caractère \n de fin de ligne.

    Rends-toi bien compte que tu as trois formats différents de données dans ton fichier :
    • La première ligne : #1 #2 #3 #4 ... pour laquelle on t'a déjà donné des pistes.
    • La deuxième ligne : Time 23:56:08 23:57:05 23:58:02 ...
    • Le reste des données.

    Il te faudra donc faire une lecture en trois étapes.
    N'hésite pas à t'inspirer des différentes discussion traitant sur la lecture de fichier, elles ne manquant pas

  2. #22
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2013
    Messages : 286
    Points : 105
    Points
    105
    Par défaut
    Bonjour, croyez moi j'ai pris presque une semaine à lire et à faire des testes sans aboutir à un résultat. Malheureusement, la plupart des documentations sur cette commande sont en anglais.

  3. #23
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2013
    Messages : 286
    Points : 105
    Points
    105
    Par défaut
    je viens de la faire avec fscanf.ça marché! mais j'ai eu un vecteur de plus les valeurs sont trop accumulées.

  4. #24
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2013
    Messages : 286
    Points : 105
    Points
    105
    Par défaut Problème avec textscan
    Bonsoir,j'ai un fichier texte organisé comme suit:
    #1 #2 ...#N
    Time 23:01 23:10 ... 03:19
    Numeric data
    Au départ j'ai pensé à ignorer les deux premières lignes comme suit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    A{i} = dlmread(fullfile(PathName, d(i).name),'\t',2,1);
    Mais apparemment c'est deux indices sont utile pour bien localiser chaque enregistrement. Avec la fameuse commande textscan, je trouve à chaque compilation une erreur ou manque de données.Quelqu'un peut m'aider svp?

  5. #25
    Invité
    Invité(e)
    Par défaut
    Commençons par le début : l'analyse des données que tu as à lire.

    Première ligne : #1 #2 #3 #4... #19 #20.
    Dans les deux fichiers que tu donnes, les chiffres vont jusqu'à 20 (qui représentera le nombre de colonnes des données qui suivent), est-ce que ce sera toujours le cas ?
    Si oui, tu pourras facilement avoir un format de lecture fixe.
    Si non, il faudra l'adapter selon ce nombre, et la lecture de la première ligne (fgetl) et son analyse pourront facilement faire ressortir ce nombre afin de pouvoir générer le format de lecture des donnes qui suivent.

    Commence par cette étape

  6. #26
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2013
    Messages : 286
    Points : 105
    Points
    105
    Par défaut
    Merci Winjerom, non les fichiers ne sont pas identiques, c'est juste un exemple que j'ai donné. Si je comprend bien le code sera comme suit:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    fid = fopen(fullfile(PathName, d(i).name),'rt'); %opening in read mode (default)
    header_char = fgetl(fid);

  7. #27
    Invité
    Invité(e)
    Par défaut
    Pour commencer oui, il te reste à analyser header_char

  8. #28
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2013
    Messages : 286
    Points : 105
    Points
    105
    Par défaut
    Tu veux dire les #1 ... etc. oui c'est ce que je trouve <1x71 char>.

  9. #29
    Invité
    Invité(e)
    Par défaut
    1x71 char ne veut pas dire grand chose.. je te parle des "vrais" numéros 1, 2...20.
    Le but est de pouvoir savoir combien il y en a puisque cela peut varier selon toi.
    Nous baserons alors la suite de la lecture sur ce nombre.
    OK ?

  10. #30
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2013
    Messages : 286
    Points : 105
    Points
    105
    Par défaut
    oui c'est ce que je trouve #1 à #20.

  11. #31
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2013
    Messages : 286
    Points : 105
    Points
    105
    Par défaut
    voila je l'ai testé sur 2 fichiers différents:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    d = dir(fullfile(PathName,'*.txt'));
     
    A = cell(numel(d),1);
     
    for i = 1:numel(d)
     
    fid = fopen(fullfile(PathName, d(i).name),'rt'); %opening in read mode (default)
    A{i} = fgetl(fid);
     
    fclose(fid);
     
    end
    c'est bien le même chiffre au départ.

  12. #32
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2013
    Messages : 286
    Points : 105
    Points
    105
    Par défaut
    Bonsoir, je reviens à ce sujet toujours :
    Le but est de pouvoir savoir combien il y en a puisque cela peut varier selon toi. Nous baserons alors la suite de la lecture sur ce nombre.
    Si je comprend bien ça doit être ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    % Using fgetl and calculate number of columnes
    fid = fopen('new_test001.txt');
    str = fgets(fid);
    txt = strread(str,'%s','delimiter','\t');
    ncol = numel(txt); % nombre colonnes
    fclose(fid);
    Quelqu'un peut me dire si c'est ça exactement? Si oui, je ferais quoi par la suite merci

Discussions similaires

  1. [Débutant] Importer des caractères d'un fichier texte dans un tableau
    Par Crepit dans le forum C#
    Réponses: 7
    Dernier message: 05/02/2014, 12h18
  2. Réponses: 8
    Dernier message: 06/08/2006, 16h11
  3. PHP5: charger des fichiers textes dans une base MYSQL
    Par koueletbak dans le forum Requêtes
    Réponses: 4
    Dernier message: 23/03/2006, 12h14
  4. [Tableaux] Stocker un fichier texte dans un tableau
    Par clairette59 dans le forum Langage
    Réponses: 13
    Dernier message: 28/01/2006, 00h48
  5. Réponses: 5
    Dernier message: 15/05/2005, 09h51

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