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 :

Modification de caractére dans un txt


Sujet :

MATLAB

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    358
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 358
    Par défaut Modification de caractére dans un txt
    Bonjour , je posséde un fichier txt .Et je souhaiterais le lire et remplacer les : par des .

    J'ai utilisé le code suivant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    function charger2(obj, event)
            [FileName,PathName] = uigetfile('*.prn','sélectionnez le fichier de data');
            Nom_Fichier=FileName;
            fid=fopen(Nom_Fichier,'wt+');
            find(fid==58)=44;
            fclose(fid)
     
     
    end
    Le problème est que le fichier txt après ce code est vide.

  2. #2
    Expert confirmé
    Avatar de duf42
    Homme Profil pro
    Formateur en informatique
    Inscrit en
    Novembre 2007
    Messages
    3 111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 111
    Par défaut
    Bonjour,

    Cette ligne:
    ne veut rien dire, c'est d'ailleurs étrange que MATLAB ne te signale pas une erreur...

    Ta variable fid contient l'identifiant de ton fichier et pas du tout son contenu. Pour lire le contenu tu peux utiliser FREAD.
    De plus, tu ouvres ton fichier en écriture et tu n'écris rien dedans, tu crées donc un fichier vide...

    Ensuite pour remplacer les caractères, l'idée c'est à peu près ca:
    Ensuite il faut que tu procèdes en 2 étapes: d'abord lire le fichier (option 'rt' de FOPEN) et ensuite écrire dans le fichier (avec FWRITE par exemple et l'option 'wt' de FOPEN)

    Bonne fin d'apm,
    Duf

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour oliv27400,

    C'est normal que tu te retrouves avec un fichier vide, tu utilises la permission 'w' qui te l'écrase.
    Ouvre-le plutôt avec 'r+t'
    Ensuite ta variable fid ne contient que le handle de ton fichier, et en aucun cas ce qu'il contient. Tu ne peux donc pas faire
    Qui n'est d'ailleur pas correct
    Pour lire les caractères 1 à 1 utilise
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    c = fscanf(fid,'%c',1);
    Ensuite tu peux faire un test si c'est ':' ou non, et si c'est le cas,
    après être revenu un cran en arrière:

  4. #4
    Rédacteur

    Homme Profil pro
    Comme retraité, des masses
    Inscrit en
    Avril 2007
    Messages
    2 978
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : Suisse

    Informations professionnelles :
    Activité : Comme retraité, des masses
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 2 978
    Par défaut
    Salut!
    Pourquoi utiliser Matlab pour ça? Est-ce que ça ne serait pas beaucoup plus simple avec un vulgaire éditeur de texte, par exemple Notepad?
    Jean-Marc Blanc

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    358
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 358
    Par défaut
    Je vais essayer avec vos conseil.
    De plus je suis obligé d'utiliser matlab...contrainte imposé afin de facilité l'utilisation pour la suite.

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    358
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 358
    Par défaut
    Ok , parfait cela marche très bien avec fread, et ensuite fwrite

    merci

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    358
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 358
    Par défaut
    Bonjour je reviens sur ce sujet qui a été résolu.Mais je souhaite désormais changer des valeurs numérique.
    Je souhaite changer des 16 par un vide NaN; si quelquu'un a une idée?

  8. #8
    Membre émérite
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    640
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 640
    Par défaut
    Cet exemple devrait te mettre sur la voie

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    A=16
     
    A(A==16)=NaN

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

Discussions similaires

  1. [Batch] Modification d'une chaîne de caractères dans un txt zippé
    Par Ristoune dans le forum Scripts/Batch
    Réponses: 2
    Dernier message: 16/03/2014, 19h07
  2. [RegEx] modification de caractère dans un context donné
    Par damaskinos dans le forum Langage
    Réponses: 7
    Dernier message: 08/04/2013, 17h33
  3. Remplacer chaine de caractère dans fichier .txt
    Par lepiaf69 dans le forum VB.NET
    Réponses: 6
    Dernier message: 07/09/2010, 15h57
  4. Modification de caractére dans un xls
    Par oliv27400 dans le forum MATLAB
    Réponses: 3
    Dernier message: 11/06/2010, 14h37
  5. [VBA] remplacer des caractères dans un .txt
    Par Frenchguy dans le forum VBA Access
    Réponses: 2
    Dernier message: 10/05/2007, 16h16

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