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

Langage Delphi Discussion :

problème avec un TStringList


Sujet :

Langage Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    programmeur
    Inscrit en
    Août 2023
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : programmeur
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2023
    Messages : 33
    Par défaut problème avec un TStringList
    Bonjour,

    Voici la description de mon objet :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
      TdtmDataModule = class(TDataModule)
        procedure DataModuleCreate(Sender: TObject);
        procedure DataModuleDestroy(Sender: TObject);
      private
        { Déclarations privées }
      public
        { Déclarations publiques }
        NomMabase: string;
        MaBase: TStringList;
        DataRecord: TDataRecord;
        procedure SaveData(DataRecord: TDataRecord);
        //procedure LoadData(Index: Integer);
        procedure LoadData(Index: Integer; var Enregistrement : string);
      end;
    et la procédure qui me pose des problèmes :

    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
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    procedure TdtmDataModule.LoadData(Index: Integer; var Enregistrement : string);
    var
      DataRecord: TDataRecord;
    //  Enregistrement: String;
      Texte: String;
      GuidOperation: TGUID;
      Longueur : Integer;
    begin
      //
      if FileExists(NomMabase) then
      begin
     
        MaBase.LoadFromFile(NomMabase);
     
        Enregistrement := MaBase.ValueFromIndex[0];
     
    //    Enregistrement := IntToStr(MaBase.Count);
     
     
      Longueur := MaBase.Count;
     
     
    //    Enregistrement := MaBase.ValueFromIndex[Index];
     
     
     
     
    //    Enregistrement := MaBase.ValueFromIndex[Index];
        Enregistrement := MaBase.ValueFromIndex[Index];
     
     
        Texte := Copy(Enregistrement, 2, 38);
        DataRecord.GUID := StringToGUID(Texte);
        delete(Enregistrement, 1, 42);
     
        DataRecord.Date := StrToDate(Copy(Enregistrement, 1, 10));
        delete(Enregistrement, 1, 13);
     
        Texte := Copy(Enregistrement, 1, 8);
        DataRecord.Heure := StrToTime(Texte);
        delete(Enregistrement, 1, 11);
     
        Texte := Copy(Enregistrement, 1, pos('","', Enregistrement));
        DataRecord.Montant := StrToInt(Texte);
        delete(Enregistrement, 1, pos('","', Enregistrement) + 3);
     
        Texte := Copy(Enregistrement, 1, pos('","', Enregistrement));
        DataRecord.Description := Texte;
        delete(Enregistrement, 1, pos('","', Enregistrement) + 3);
     
        Texte := Copy(Enregistrement, 1, pos('","', Enregistrement));
        DataRecord.Categorie := StrToInt(Texte);
        delete(Enregistrement, 1, pos('","', Enregistrement) + 3);
     
        Texte := Copy(Enregistrement, 1, pos('","', Enregistrement));
        DataRecord.Compte := StrToInt(Texte);
        delete(Enregistrement, 1, pos('","', Enregistrement) + 3);
     
        Texte := Copy(Enregistrement, 1, pos('","', Enregistrement));
        DataRecord.Repetition := StrToInt(Texte);
        delete(Enregistrement, 1, pos('","', Enregistrement) + 3);
     
        Texte := Copy(Enregistrement, 1, pos('"', Enregistrement));
        DataRecord.Memo := Texte;
        delete(Enregistrement, 1, pos('"', Enregistrement) - 1);
        // delete(Enregistrement,1,StrLen(Enregistrement) - 1);
     
      end;
     
    end;
    Je n'arrive pas à récupérer mes données bien qu'en suivant le processus, le TstringList contient bien les éléments. Je ne comprends pas pourquoi il me retourne une chaine vide lorsque je pointe sur le premier élément de mon fichier.

    Si vous avez une petite idée pour m'aider.

    Merci pour vos réponses.

  2. #2
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 14 101
    Par défaut


    Pas de boucle pour lire chaque ligne ?
    Index de 0 à Count - 1, c'est Zero based et non One Based, un piège pour débutant (la string est one-based en VCL par exemple)

    Tous ces Delete, c'est pratique car évite de gérer le décalage de positionnement mais c'est très lent.

    Cela semble séparer par ,
    une sorte de CSV ?
    attention, le CSV américain c'est , le délimiter mais un CSV français c'est ; à cause de la différence de séparateur décimal respectivement . et ,

    Une seconde TStringList en StrictDelimiter pourra découper l'enregistrement
    Je préfére ExtractStrings ou ma propre fonction bien plus performante (avec FastMM) soit ExplodeLazy mentionné dans Chargement d'un fichier CSV dans une FDMemTable .

    Stocker une base de données en fichier texte lu par une TStringList, c'est pauvre, c'est bien pour découvrir cette fonctionnalité lors d'un devoir scolaire, pour un professionnel, il faut songer à une solution plus évolutive, un XML avec TClientDataSet, un JSON avec TJSONObject si le mode fichier est vraiment requis sinon un SQLite semble bien mieux.
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  3. #3
    Rédacteur/Modérateur
    Avatar de Andnotor
    Inscrit en
    Septembre 2008
    Messages
    5 943
    Détails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Septembre 2008
    Messages : 5 943
    Par défaut
    C'est plutôt un extrait du fichier qu'il faudrait fournir.

    ValueFromIndex va retourne la partie à droite du signe égal dans une paire nom=valeur.
    Pour une ligne complète ce sera simplement MaBase[Index].

  4. #4
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 663
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 663
    Billets dans le blog
    65
    Par défaut
    Citation Envoyé par ShaiLeTroll Voir le message
    Je préfère ExtractStrings
    Je lui préfère Split ou SplitString

  5. #5
    Membre actif
    Homme Profil pro
    programmeur
    Inscrit en
    Août 2023
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : programmeur
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2023
    Messages : 33
    Par défaut Merci
    Merci pour tous vos conseils, mon problème est résolu. Bien vu pour le ; comme séparateur, j'arrive à lire mon fichier dans Excel sans problème et enfin à lire mon fichier dans mon application.
    Encore un grand merci à tous.

    Pascal.

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

Discussions similaires

  1. Problème avec GetTextBuf dans TStringList
    Par frantzgac dans le forum Langage
    Réponses: 2
    Dernier message: 24/09/2009, 17h20
  2. VC++ Direct3D8, problème avec LPD3DXFONT et LPD3DTEXTURE8
    Par Magus (Dave) dans le forum DirectX
    Réponses: 3
    Dernier message: 03/08/2002, 11h10
  3. Problème avec le type 'Corba::Any_out'
    Par Steven dans le forum CORBA
    Réponses: 2
    Dernier message: 14/07/2002, 18h48
  4. Problème avec la mémoire virtuelle
    Par Anonymous dans le forum CORBA
    Réponses: 13
    Dernier message: 16/04/2002, 16h10

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