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 Java Discussion :

Lecture fichier Plat avec délimiteurs et insertion données dans mysql


Sujet :

Langage Java

  1. #1
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut Lecture fichier Plat avec délimiteurs et insertion données dans mysql
    Bonjour,
    Depuis ce matin ,j'essayes de construire une classe main qui va lire un fichier plat qui contient plusieurs lignes(chaque ligne contient des données séparés par le délimiteurs "|;").
    et après mon programme doit pouvoir extraire les 4 derniers données dans chaque ligne du fichier et les mettre à jour dans une table mysql(ce n'est pas le problème que j'ai),le problème c'est que le programme boucle en extractant tous les lignes mais sans différencier entre chaque ligne .
    voila la structure du fichier:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    AG0001|;78015|;MRE|;Mlle|;cliente1|;prenomS|;1952-02-02|;eljadida|;Ma|;Ma|;4702|;Contrôleurs*laitiers,*inséminateurs*et*autres*agents*techniques*agricoles|;adresse15445qsd|;sqdqsd|;casablanca-maroc|;20200|;amiens|;Ma|;+33|;654564|;+33|;061231137|;CNI|;|;2020-04-02|;KO|;inssufissance au niveau solde client|;1700022656672011270000026215000071365|;N
     
    AG0003|;78015|;MRE|;Mlle|;cliente2|;yyy|;1986-02-02|;marrakech|;Ma|;Ma|;1102|;Maraîchers,*horticulteurs*sur*petite*exploitation|;adresse121881|;sqd|;casablanca-maroc|;20200|;bordeaux|;Ma|;+33|;654|;+33|;052323212|;PAS|;|;2020-02-12|;KO|;inssufissance au niveau solde client|;1700022656672011270000026215000071365|;N
    ...
    voila la classe main:
    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
     
     
            String file = "C:\\Users\\belkaika\\Desktop\\batch_INJECT_TIERS_PROSPECTS\\RTR_INJECT_TIERS_PROSPECTS.txt";
            String line;
            System.out.println ("fichier spécifié = " + file);
     
            ArrayList <String> words = new ArrayList<String> ();
     
            BufferedReader br =  new BufferedReader (new FileReader (file)); //içi j'utilisais ce buffer quand je testai : while ((line  = br.readLine()) != null)
            try{
                while ((line  = br.readLine()) != null) {
     
                    StringTokenizer token = new StringTokenizer (line,"|;");
                    String[] List = new String [token.countTokens()];
                     int i = 0;
                    while(token.hasMoreTokens()){
     
                     List[i] = token.nextToken();
                     System.out.println ("List[i] est égale = " + List[i]);
                     //ici comment extraire seulement les 4 derniers données de chaque ligne délimités par le délimiteur "|;"
                     i++;
     
                    }
                       // words.add(token.nextToken());
     
                }
            }
            catch (IOException e) {
     
                System.out.println (e.getMessage());
                e.printStackTrace();
     
            } finally {
                br.close();
            }
    l'outpout généré est le suivant:
    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
     
    List[i] est égale = AG0001
    List[i] est égale = 78015
    List[i] est égale = MRE
    List[i] est égale = Mlle
    List[i] est égale = cliente1
    List[i] est égale = prenomS
    List[i] est égale = 1952-02-02
    List[i] est égale = eljadida
    List[i] est égale = Ma
    List[i] est égale = Ma
    List[i] est égale = 4702
    List[i] est égale = Contrôleurs*laitiers,*inséminateurs*et*autres*agents*techniques*agricoles
    List[i] est égale = adresse15445qsd
    List[i] est égale = sqdqsd
    List[i] est égale = casablanca-maroc
    List[i] est égale = 20200
    List[i] est égale = amiens
    List[i] est égale = Ma
    List[i] est égale = +33
    List[i] est égale = 654564
    List[i] est égale = +33
    List[i] est égale = 061231137
    List[i] est égale = CNI
    List[i] est égale = 2020-04-02
    List[i] est égale = KO
    List[i] est égale = inssufissance au niveau solde client
    List[i] est égale = 1700022656672011270000026215000071365
    List[i] est égale = N
    List[i] est égale = AG0003
    List[i] est égale = 78015
    List[i] est égale = MRE
    List[i] est égale = Mlle
    List[i] est égale = cliente2
    List[i] est égale = yyy
    List[i] est égale = 1986-02-02
    List[i] est égale = marrakech
    List[i] est égale = Ma
    List[i] est égale = Ma
    List[i] est égale = 1102
    List[i] est égale = Maraîchers,*horticulteurs*sur*petite*exploitation
    List[i] est égale = adresse121881
    List[i] est égale = sqd
    List[i] est égale = casablanca-maroc
    List[i] est égale = 20200
    List[i] est égale = bordeaux
    List[i] est égale = Ma
    List[i] est égale = +33
    List[i] est égale = 654
    List[i] est égale = +33
    List[i] est égale = 052323212
    List[i] est égale = PAS
    List[i] est égale = 2020-02-12
    List[i] est égale = KO
    List[i] est égale = inssufissance au niveau solde client
    List[i] est égale = 1700022656672011270000026215000071365
    List[i] est égale = N
    Merci de m'aviser sur ce problème .

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Citation Envoyé par karimoscapitated Voir le message
    le problème c'est que le programme boucle en extractant tous les lignes mais sans différencier entre chaque ligne .
    Si, bien sûr. C'est juste ton affichage qui est mal placé et qui te fait penser ça.

    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
     
     
     
         String[] List = new String [token.countTokens()];
         int i = 0;
         while(token.hasMoreTokens()){
     
             List[i] = token.nextToken();
             //System.out.println ("List[i] est égale = " + List[i]);
            //ici comment extraire seulement les 4 derniers données de chaque ligne délimités par le délimiteur "|;"
            i++;
     
         }
     
         // ici List contient l'ensemble des mots de la ligne en cours
         System.out.println(Arrays.toString( List ) ); // affiche l'ensemble des valeurs de la ligne
     
         System.out.println("Affichage des 4 dernières valeurs : ");
         for(int index = List.length-4; index<List.length; index++) {
             System.out.println(List(index));
         }
     
         // donc ici tu peux stocker les 4 dernières colonnes dans un enregistrement de ta base
     
         // words.add(token.nextToken());
     
    }
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    Merci pour votre réponse.
    j'ai essayé d'utiliser cette méthode de boucle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for(int index = List.length-4; index<List.length; index++)
    mais il me donnes pas le résultat que je veux,ce que je souhaite avoir c'est que pour chaque ligne récupérer les données délimités par le truc.
    voila le résultat de console:
    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
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
    281
    282
    283
    284
    285
    286
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!KO
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!KO
    affichage List[index] !!!!!!!!!!!!inssufissance au niveau solde client
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!KO
    affichage List[index] !!!!!!!!!!!!inssufissance au niveau solde client
    affichage List[index] !!!!!!!!!!!!1700022656672011270000026215000071365
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!KO
    affichage List[index] !!!!!!!!!!!!inssufissance au niveau solde client
    affichage List[index] !!!!!!!!!!!!1700022656672011270000026215000071365
    affichage List[index] !!!!!!!!!!!!N
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!KO
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!KO
    affichage List[index] !!!!!!!!!!!!inssufissance au niveau solde client
    affichage List[index] !!!!!!!!!!!!null
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!KO
    affichage List[index] !!!!!!!!!!!!inssufissance au niveau solde client
    affichage List[index] !!!!!!!!!!!!1700022656672011270000026215000071365
    affichage List[index] !!!!!!!!!!!!null
    ................
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!KO
    affichage List[index] !!!!!!!!!!!!inssufissance au niveau solde client
    affichage List[index] !!!!!!!!!!!!1700022656672011270000026215000071365
    affichage List[index] !!!!!!!!!!!!null
    Affichage des 4 dernières valeurs : 
    affichage List[index] !!!!!!!!!!!!KO
    affichage List[index] !!!!!!!!!!!!inssufissance au niveau solde client
    affichage List[index] !!!!!!!!!!!!1700022656672011270000026215000071365
    affichage List[index] !!!!!!!!!!!!N
    ici il récupéres le champs en question jusqu'à la fin de boucle comme vous le constatez.


    Merci pour votre aide.

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par karimoscapitated Voir le message
    c'est que pour chaque ligne récupérer les données délimités par le truc.
    c'est quoi le "truc" ? Délimitées où ? Dans les colonnes, les lignes ?

    Citation Envoyé par karimoscapitated Voir le message
    ici il récupéres le champs en question jusqu'à la fin de boucle comme vous le constatez.
    C'est bien ce que tu as demandé... récupérer les 4 dernières colonnes de chaque ligne. Si tu as besoin d'autre chose, il faut le préciser dans ta question. On ne peut pas deviner.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  5. #5
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    ouii désolé j'ai pas bien expliqué,délimités par "|;" je veux dire.
    j'ai appliquer quelques changements sur la boucle que tu m'as envoyé,et le résultat est bien ce que je veux ;je récupères les 4 derniers champs de la liste de données de chaque ligne.
    Maintenant ,si je veux utiliser ces données pour mettre à jour une table mysql ,dois-je placer le traitement au sein de la boucle suivante?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    for(int index = List.length-4; index<List.length; index++)
    {
                            System.out.println(List[index]);
    //est ce que c'est içi que je dois mettre la partie MAJ de la BDD?
                        }
    Merci pour votre aide @joel.drigo

  6. #6
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Je t'ai indiqué dans mon exemple, par le commentaire // donc ici tu peux stocker les 4 dernières colonnes dans un enregistrement de ta base, où tu devais insérer ton code de stockage en base.

    Par exemple, tu peux faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    /*...*/
    System.out.println("Affichage des 4 dernières valeurs : ");
         for(int index = List.length-4; index<List.length; index++) {
             System.out.println(List(index));
         }
     
         // donc ici tu peux stocker les 4 dernières colonnes dans un enregistrement de ta base
         storeInDB( Arrays.copyOf(List, List.length-4, List.length));
     
    /*...*/
    Et faire une méthode comme ça par exemple :
    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
     
    public void storeInDB( String...values ) {
     
         ...type de la valeur0 ?... valeur0 = convertToTypeDeLaValeur0(values[0]);
         ...type de la valeur1 ?... = convertToTypeDeLaValeur1(values[1]);
         ...type de la valeur2 ?... = convertToTypeDeLaValeur2(values[2]);
         ...type de la valeur3 ?... = convertToTypeDeLaValeur3(values[3]);
     
         try(PreparedStatement ps = getConnection().prepareStatement("Insert into machin values(?,?,?,?)")) {
     
                ps.setXXX(1, valeur0); // setXXX c'est set approprié en fonction du type de la valeur (que je ne connais pas)
                ps.setXXX(2, valeur1); // setXXX c'est set approprié en fonction du type de la valeur (que je ne connais pas)
                ps.setXXX(3, valeur2); // setXXX c'est set approprié en fonction du type de la valeur (que je ne connais pas)
                ps.setXXX(4, valeur3); // setXXX c'est set approprié en fonction du type de la valeur (que je ne connais pas)
     
                ps.executeUpdate();
     
         }
     
    }
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  7. #7
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    Ouii exactement ,je viens de le voir désolé,
    voila la méthode:
    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
       public void StoreInDB(String codeRetour, String motif, String numTiers, String topExist)
        {
            try 
            {           String myDriver = "com.mysql.jdbc.Driver";
                        String myUrl = "jdbc:mysql://localhost:3306/agencedirect";
                        Class.forName(myDriver);
                        Connection conn = (Connection) DriverManager.getConnection(myUrl, "root", ""); 
                        String select = "update questionnaire set codeRetour = '"+codeRetour+"',motif = '"+motif+"',numTiers='"+numTiers+"',topExist='"+topExist+"' where  numDossier = '"+numDossier+"' ";
     
                        PreparedStatement pst = conn.prepareStatement(select);
     
                        pst.setString(1, codeRetour);
                        pst.setString(2, motif);
                        pst.setString(3, numTiers);
                        pst.setString(4, topExist);
     
                        pst.executeUpdate();
                        System.out.println("La BD à été MAJ avec succés");
     
            }
            catch (Exception e)
            {
                e.printStackTrace();
            } 
        }
    en paramètres de cette fonction j'ai mis (String codeRetour, String motif, String numTiers, String topExist),pour qu'elle permette de faire l'update des 4 derniers champs en question.
    Ainsi pour la requete ,comment je dois me positionner sur l'enregistrement dans la table (j'ai opté ici pour le: WHERE numDossier = '"+numDossier+"' " ,mais le problème que je dois le récupérer aussi de la List des données ? ou bien je pourrai faire autrement?)
    sinon pour l'appel de la méthode
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     StoreInDB( Arrays.copyOf(List, List.length-4, List.length));
    ne fonctionnes pas dans ce cas ,est ce que je dois changer l'appel ou bien changer le type de méthode carrément?

    Merci pour votre aide @joel.drigo

  8. #8
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Bah, oui, là, ça ne peut pas marcher parce que tu as déclaré ta signature de méthode avec 4 paramètres de type Stirng alors qu'on l'appelle en passant un tableau !
    Il faut appelle une méthode en passant les paramètres qu'elle attend : un tableau ne peut être converti automatiquement en n variables en Java !

    Mais tu peux faire une seconde méthode qui fait cette "conversion" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    public void storeInDB( String...values ) {
          StoreInDb(values[0], values[1], values[2], values[3]); // on appelle l'autre méthode avec 4 paramètres, en passant les valeurs ad hoc dans le tableau
    }
    Non :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
           String select = "update questionnaire set codeRetour = '"+codeRetour+"',motif = '"+motif+"',numTiers='"+numTiers+"',topExist='"+topExist+"' where  numDossier = '"+numDossier+"' ";
    Regarde mon exemple : les paramètres sont sous forme de ?, pas des valeurs concaténées. On ne concatène pas les valeurs en dur dans la requête d'un PreparedStatement, justement pour pouvoir bénéficier du remplissage automatique (traitement automatique des quotes entre autres).
    Question annexe : d'où vient numDossier ? Normalement, on devrait le passer en paramètre de la méthode StoreInDB (si c'est une variable de classe, alors on mettra à jour une et une seule ligne de la table questionnaire, avec des données venant de plusieurs lignes dans le fichier : incohérence ! Cette valeur ne doit-elle pas aussi venir du fichier ?


    Par ailleurs :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    pst.executeUpdate();
    System.out.println("La BD à été MAJ avec succés");
    La méthode executeUpdate() retourne le nombre d'éléments mis à jour : je te conseille donc de tester cette valeur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    int resultat = pst.executeUpdate();
    switch(resultat) {
    case 0:
        System.out.println("Attention : aucun enregistrement n'a été mis à jour");
        break;
    case 1:
        System.out.println("La BD à été MAJ avec succés");
        break;
    default:
        System.out.println("Plusieurs enregistrement ont été mis à jour ("+resultat+")!!!");
        break;
    }




    Accessoirement, il y a des conventions d'écriture en Java : entre autres, les noms de méthode et de variables doivent commencer par une minuscule.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  9. #9
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    j'ai placé la méthode dont vous m'avez parler,Merci déjà pour toutes ces explications.
    Réponse Question annexe :
    Oui effectivement ce champ dans la BDD vient dans le fichier c'est le 1er champ de chaque ligne(AG001 ex) dans le fichier.voir exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    AG0001|;78015|;MRE|;Mlle|;cliente1|;prenomS|;1952-02-02|;eljadida|;Ma|;Ma|;4702|;Contrôleurs*laitiers,*inséminateurs*et*autres*agents*techniques*agricoles|;adresse15445qsd|;sqdqsd|;casablanca-maroc|;20200|;amiens|;Ma|;+33|;654564|;+33|;061231137|;CNI|;|;2020-04-02|;KO|;inssufissance au niveau solde client|;1700022656672011270000026215000071365|;N
     
    AG0003|;78015|;MRE|;Mlle|;cliente2|;yyy|;1986-02-02|;marrakech|;Ma|;Ma|;1102|;Maraîchers,*horticulteurs*sur*petite*exploitation|;adresse121881|;sqd|;casablanca-maroc|;20200|;bordeaux|;Ma|;+33|;654|;+33|;052323212|;PAS|;|;2020-02-12|;KO|;inssufissance au niveau solde client|;1700022656672011270000026215000071365|;N
    ...
    justement pour l'update il faut obligatoirement mettre à jour en fonction du "num_dossier" pour savoir quel enregistrement va etre mise à jour,ou bien on pourra le faire autrement ?
    voila le 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
    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
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
     public static void main(String[] args) throws FileNotFoundException, IOException {
     
            String file = "C:\\Users\\belkaika\\Desktop\\batch_INJECT_TIERS_PROSPECTS\\RTR_INJECT_TIERS_PROSPECTS.txt";
            String line;
            System.out.println ("fichier spécifié = " + file);
     
            BufferedReader br =  new BufferedReader (new FileReader (file));
            try    {
                while ((line  = br.readLine()) != null) {
     
                    StringTokenizer token = new StringTokenizer (line,"|;");
                    String[] List = new String [token.countTokens()];
                     int i = 0;
                        while(token.hasMoreTokens()){
     
                         List[i] = token.nextToken();
                         i++;
                         //System.out.println ("List[i] est égale = " + List[i]);
                        }
                   // ici List contient l'ensemble des mots de la ligne en cours
                    System.out.println("valeurs de la ligne"+Arrays.toString(List)); // affiche l'ensemble des valeurs de la ligne
     
                    System.out.println("Affichage des 4 dernières valeurs : ");
                        for(int index = List.length-4; index<List.length; index++) {
                            System.out.println(List[index]);
     
                        }
                        storeInDB(Arrays.copyOf(List,List.length-4,List.length));//ici il me donnes une erreur"no suitable method found for copyOf(String[],int,int)"
                      }
     
     
                    }
     
            catch (IOException e) {
     
                System.out.println (e.getMessage());
                e.printStackTrace();
     
            } finally {
                br.close();
            }
     
        }
        public void storeInDb(String codeRetour, String motif, String numTiers, String topExist)
        {
            try 
            {           String myDriver = "com.mysql.jdbc.Driver";
                        String myUrl = "jdbc:mysql://localhost:3306/agencedirect";
                        Class.forName(myDriver);
                        Connection conn = (Connection) DriverManager.getConnection(myUrl, "root", ""); 
                        String select = "update questionnaire set codeRetour = ?,motif = ?,numTiers=?,topExist=? where  numDossier = ? ";
     
                        PreparedStatement pst = conn.prepareStatement(select);
     
                        pst.setString(1, codeRetour);
                        pst.setString(2, motif);
                        pst.setString(3, numTiers);
                        pst.setString(4, topExist);
     
     
                        int resultat = pst.executeUpdate();
                        switch(resultat) {
                        case 0:
                            System.out.println("Attention : aucun enregistrement n'a été mis à jour");
                            break;
                        case 1:
                            System.out.println("La BD à été MAJ avec succés");
                            break;
                        default:
                            System.out.println("Plusieurs enregistrement ont été mis à jour ("+resultat+")!!!");
                            break;
                        }
            }
            catch (Exception e)
            {
                e.printStackTrace();
            } 
        }
        public void storeInDB( String...values ) {
          storeInDb(values[0], values[1], values[2], values[3]); // on appelle l'autre méthode avec 4 paramètres, en passant les valeurs ad hoc dans le tableau
    }
    Merci pour ton aide,ainsi que vos explications .

  10. #10
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par karimoscapitated Voir le message
    //ici il me donnes une erreur"no suitable method found for copyOf(String[],int,int)"
    j'ai fait une petite erreur tout à l'heure : la méthode de copie partielle du tableau, c'est copyOfRange au lieu de copyOf
    Citation Envoyé par karimoscapitated Voir le message
    Oui effectivement ce champ dans la BDD vient dans le fichier c'est le 1er champ de chaque ligne(AG001 ex) dans le fichier.voir exemple:
    [...]
    justement pour l'update il faut obligatoirement mettre à jour en fonction du "num_dossier" pour savoir quel enregistrement va etre mise à jour,ou bien on pourra le faire autrement ?
    Dans ce cas, il faut également récupérer ce champ et le passer à la méthode pour pouvoir l'utiliser dans l'update :

    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
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    public static void main(String[] args) throws FileNotFoundException, IOException {
     
    	        String file = "C:\\Users\\belkaika\\Desktop\\batch_INJECT_TIERS_PROSPECTS\\RTR_INJECT_TIERS_PROSPECTS.txt";
    	        String line;
    	        System.out.println ("fichier spécifié = " + file);
     
    	        BufferedReader br =  new BufferedReader (new FileReader (file));
    	        try    {
    	            while ((line  = br.readLine()) != null) {
     
    	                StringTokenizer token = new StringTokenizer (line,"|;");
    	                String[] List = new String [token.countTokens()];
    	                 int i = 0;
    	                    while(token.hasMoreTokens()){
     
    	                     List[i] = token.nextToken();
    	                     i++;
    	                     //System.out.println ("List[i] est égale = " + List[i]);
    	                    }
    	               // ici List contient l'ensemble des mots de la ligne en cours
    	                System.out.println("valeurs de la ligne"+Arrays.toString(List)); // affiche l'ensemble des valeurs de la ligne
     
    	                System.out.println("Affichage des 4 dernières valeurs : ");
    	                    for(int index = List.length-4; index<List.length; index++) {
    	                        System.out.println(List[index]);
     
    	                    }
    	                    storeInDB(List[0], Arrays.copyOfRange(List,List.length-4,List.length));
    	                  }
     
     
    	                }
     
    	        catch (IOException e) {
     
    	            System.out.println (e.getMessage());
    	            e.printStackTrace();
     
    	        } finally {
    	            br.close();
    	        }
     
    	    }
    	    public static void storeInDb(String numDossier, String codeRetour, String motif, String numTiers, String topExist)
    	    {
    	        try 
    	        {           String myDriver = "com.mysql.jdbc.Driver";
    	                    String myUrl = "jdbc:mysql://localhost:3306/agencedirect";
    	                    Class.forName(myDriver);
    	                    String select = "update questionnaire set codeRetour = ?,motif = ?,numTiers=?,topExist=? where  numDossier = ? ";
    	                    try(Connection conn = (Connection) DriverManager.getConnection(myUrl, "root", ""); 
    	                    PreparedStatement pst = conn.prepareStatement(select);) {
     
    	                    pst.setString(1, codeRetour);
    	                    pst.setString(2, motif);
    	                    pst.setString(3, numTiers);
    	                    pst.setString(4, topExist);
     
    	                    pst.setString(5, numDossier);
     
    	                    System.out.println("MAJ dossier " + numDossier);
    	                    int resultat = pst.executeUpdate();
    	                    switch(resultat) {
    	                    case 0:
    	                        System.out.println("Attention : aucun enregistrement n'a été mis à jour");
    	                        break;
    	                    case 1:
    	                        System.out.println("La BD à été MAJ avec succés");
    	                        break;
    	                    default:
    	                        System.out.println("Plusieurs enregistrement ont été mis à jour ("+resultat+")!!!");
    	                        break;
    	                    }
     
                       }
            }
            catch (Exception e)
            {
                e.printStackTrace();
            } 
       }
       public static void storeInDB( String numDossier, String...values ) {
          storeInDb(numDossier, values[0], values[1], values[2], values[3]); // on appelle l'autre méthode avec 4 paramètres, en passant les valeurs ad hoc dans le tableau
       }
    De plus, comme tu appelles les méthodes storeInDB depuis la méthode main, une méthode static, les méthodes storeInDB doivent également être static.

    Attention : il est important de fermer les connexions, statements (et resultset le cas échéant) après les avoir utilisé. Dans le code ci-dessus, je le fais par un try-with-resources.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  11. #11
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    Merci infiniment @joel.drigo,le programme permet maintenant de faire l'update.
    sinon une dernière question svp,c'est que pour la déclaration du chemin du fichier à lire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String file = "C:\\Users\\belkaika\\Desktop\\batch_INJECT_TIERS_PROSPECTS\\RTR_INJECT_TIERS_PROSPECTS.txt";
    parfois le fichier arrive sous le nom "RTR_INJECT_TIERS_PROSPECTS_13042016.txt",et il le programme doit le traiter,donc içi je dois lui donner un chemin relatif genre ...RTR_INJECT_TIERS_PROSPECTS%.txt?
    ou bien d'utiliser les propriètés de classe File
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (if(f.getName().contains"RTR_INJECT_TIERS_PROSPECTS."))
    je vous remercie pour votre soutien,c'est gentil de votre part.

  12. #12
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Premièrement, il y a l'aspect récupération du fichier : pour ça tu peux utiliser un FileFilter avec la méthode listFile() de File et une expression régulière pour tester le nom du fichier :

    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
    public static File getFile(File directory, final Pattern fileFilter) {
     
    		File[] files = directory.listFiles(new FileFilter() {
     
    			@Override
    			public boolean accept(File pathname) { 
    				return fileFilter.matcher(pathname.getName()).matches();
    			}
     
    		}); 
     
    		if ( files==null || files.length==0 ) {
    			return null; // pas de fichier trouvé
    		}
    		return files[0]; // retourne le premier fichier trouvé
     
    	}
    Que tu peux appeler par exemple comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    public class Truc { 
        private final static File DIRECTORY = new File("C:\\Users\\belkaika\\Desktop\\batch_INJECT_TIERS_PROSPECTS\\");
        private final static Pattern FILE_FILTER=Pattern.compile("RTR_INJECT_TIERS_PROSPECTS[^.]*\\.txt"); // pour accèder à tous les fichiers qui commencent par RTR_INJECT_TIERS_PROSPECTS, avec juste une extension .txt
     
        public static void main(String[] args) {
                  File file = getFile(DIRECTORY, FILE_FILTER); // attention file peut être null (si aucun fichier ne correspond à la recherche)
        }
     
    }
    Ensuite, questions :

    1. peut-il y avoir plusieurs fichiers ? Si oui, il faudra faire une boucle tant que la méthode getFile() ne retourne pas null
    2. si ces fichiers peuvent arriver n'importe quand, et le programme doit tourner en continu et réagir à l'arrivée d'un (ou plusieurs) fichier(s). Dans ce, regarde les Watch Services.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  13. #13
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    bonjour @joel.drigo,
    je suis entrain d'intégrer cette fonction je crois que çela va marcher.
    concernant vos questions:
    il peut y avoir seulement un seul fichier,donc un seul traité et le batch est lancé manuellement ,il ne sera pas programmé pour qu'il tournes périodiquement.
    Merci pour votre aide @joel.drigo,à bientôt.

  14. #14
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par karimoscapitated Voir le message
    il peut y avoir seulement un seul fichier,donc un seul traité et le batch est lancé manuellement ,il ne sera pas programmé pour qu'il tournes périodiquement.
    Dans ce cas, une autre solution, plus simple peut-être, est de passer le nom du fichier en paramètre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    public static void main(String[] args) {
     
         if ( args.length==0 ) {
                 System.err.println("Veuillez indiquer le nom du fichier en paramètre...");
         }
         else {
                File file = new File(args[0]);
                /*...*/
         }
     
    }
    Il suffit de lancer le programme dans le dossier du fichier. Par exemple, tu fais un .cmd :

    Code machin.cmd : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    cd C:\Users\belkaika\Desktop\batch_INJECT_TIERS_PROSPECTS\
    java lenomdetaclass %1

    et tu exécutes :
    Code cmd : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    >machin.cmd RTR_INJECT_TIERS_PROSPECTS.txt
    >machin.cmd RTR_INJECT_TIERS_PROSPECTS_11.txt

    Avec la complétion, ça ne demande pas trop de frappe
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  15. #15
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    Ouii vous avez raison Mr @joel.drigo,mais dans le cas que j'ai maintenant,dans chaque jour un seul fichier sera traité donc on aura pas ce soucis,sinon pour la méthode de lancement en mode batch,c'est bien ce que vous avez mentionné en bout de code,je vais faire de meme .
    En plus j'ai intégré la méthode"getFile" et ça marche bien maintenant ,le programme traite les fichiers avec nomenclature de type :
    RTR_INJECT_TIERS_PROSPECTS_11...
    Merci infiniment @joel.drigo de m'avoir aidé à résoudre tous ces problèmes .

    Bonne journée

  16. #16
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    Bonjour @joel.drigo,

    je reviens vers vous j'ai un petit soucis SVP ,dans le cas ou on a un champ dans le fichier qui vient vide comme ceci par exemple(plus spécifiquement les 4 derniers champs ):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AG0001|;78015|;....|;2020-04-02|;KO|;TITRE INCORRECT|;|;N
    Dans ce cas ,il prends les champs suivants:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    2020-02-12
    KO
    TITRE INCORRECT
    N
    alors qu'il doit commencer par le "KO".
    dans la partie code on a prévu ceci :
    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
      try    
            {
                while ((line  = br.readLine()) != null) 
                {
     
                    StringTokenizer token = new StringTokenizer (line,"|;");
                    String[] List = new String [token.countTokens()];
                     int i = 0;
                        while(token.hasMoreTokens())
                        {
                         List[i] = token.nextToken();
                         i++;
                         //System.out.println ("List[i] est égale = " + List[i]);
                        }
                   // ici List contient l'ensemble des mots de la ligne en cours
                    System.out.println("valeurs de la ligne"+Arrays.toString(List)); // affiche l'ensemble des valeurs de la ligne
     
                    System.out.println("Affichage des 4 dernières valeurs : ");
                        for(int index = List.length-4; index<List.length; index++) {
                            System.out.println(List[index]);
     
                        }
                         storeInDB(List[0], Arrays.copyOfRange(List,List.length-4,List.length));
                }
                       // words.add(token.nextToken());
     
            }
    est ce que vous avez svp une visibilité sur ce problème,c'est à dire comment lire le fichier et s'il trouves un champ renseigné à vide entre deux séparateurs '|;' ,il le considère comme une valeur vide .

    Merci d'avance JOEL

  17. #17
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    C'est un problème classique avec le StringTokenizer : les tokens vides sont toujours éliminés de la réponse.

    Depuis Java 5, la classe String dispose d'une méthode qui permet de subdiviser une chaîne en plusieurs chaînes en utilisant une expression régulière. En plus, elle retourne un tableau, qui est souvent plus facile à manipuler. Toutefois, cette méthode réalise également certaines éliminations, en particulier les tokens vides de fin. Un paramètre appelé limite permet de palier ce problème lorsqu'on lui donne la valeur -1.

    L'équivalent en expression régulière de tes séparateurs est tout simplement "[|;]".

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String[] tokens =  line.split("[|;]", -1);
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  18. #18
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    bonjour,

    si j'ai bien compris ,je dois changer la déclaration de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String[] List = new String [token.countTokens()];
    ou bien la déclaration du token
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StringTokenizer token = new StringTokenizer (line,"|;");
    ?

    j'aurai je veux dire qqch comme ça non ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     StringTokenizer token = new StringTokenizer (line,"|;");
                    String[] List =  line.split("[|;]", -1);
                   // String[] List = new String [token.countTokens()];
                     int i = 0;
                        while(token.hasMoreTokens())
                        {
                         List[i] = token.nextToken();
                         i++;}

  19. #19
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Non, supprime tout simplement le StringTokenizer :

    Au lieu de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    StringTokenizer token = new StringTokenizer (line,"|;");
    	                String[] List = new String [token.countTokens()];
    	                 int i = 0;
    	                    while(token.hasMoreTokens()){
     
    	                     List[i] = token.nextToken();
    	                     i++;
    	                     //System.out.println ("List[i] est égale = " + List[i]);
    	                    }
    fais tout simplement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String[] List = line.split("[|;]",-1);
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  20. #20
    Membre régulier
    Homme Profil pro
    Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Inscrit en
    Août 2007
    Messages
    89
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Analyste Concepteur[Secteur Banque/assurance]/ Ingénieur d'état en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2007
    Messages : 89
    Points : 96
    Points
    96
    Par défaut
    Bonjour,
    Merci pour votre réponse @joel,

    j'ai fait comme vous l'avez mentionné ,j'ai remplacé la partie du StringTokenizer avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String[] List = line.split("[|;]",-1);
    désormais,il ne peut pas splitter le fichier comme il le faut,voici le résultat de console(sortie)
    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
    valeurs de la ligne[AG0001, , 78015, , MRE, , MLE, , bendari, , mohammed, , 1952-02-02, , eljadida, , Ma, , Ma, , 4702, , Contrôleurs*laitiers,*inséminateurs*et*autres*agents*techniques*agricoles, , adresse15445qsd, , adresse_test6, , casablanca-maroc, , 20200, , amiens, , Ma, , +33, , 6545644141, , +33, , 061231137, , CNI, , 626262, , 2020-04-02, , KO, , TITRE INCORRECT, , , , N]
    Affichage des 4 dernières valeurs : 
     
     
     
    N
    MAJ dossier ...........AG0001
    La BD à été MAJ avec succés
    valeurs de la ligne[AG0003, , 78015, , MRE, , MLE, , benjeloun, , ahmed, , 1986-02-02, , marrakech, , Ma, , Ma, , 1102, , Maraîchers,*horticulteurs*sur*petite*exploitation, , adresse121881, , adresse_test5, , casablanca-maroc, , 20200, , bordeaux, , Ma, , +33, , 65444141, , +33, , 052323212, , PAS, , 626262, , 2020-02-12, , KO, , TITRE INCORRECT, , , , N]
    Affichage des 4 dernières valeurs : 
     
     
     
    N
    MAJ dossier ...........AG0003
    La BD à été MAJ avec succés
    valeurs de la ligne[AG0002, , 78015, , MRE, , M, , benanni, , fatima, , 1980-02-02, , casablanca, , Ma, , Ma, , 2105, , bmce, , paris-france, , adresse_test4, , casablanca-maroc, , 30200, , paris, , FR, , +33, , 65456444, , +33, , 061231138, , CDS, , 626262, , 2020-06-02, , KO, , TITRE INCORRECT, , , , N]
    Affichage des 4 dernières valeurs : 
     
     
     
    N
    MAJ dossier ...........AG0002
    La BD à été MAJ avec succés
    valeurs de la ligne[AG0004, , 78015, , MRE, , M, , client1, , hamid, , 1967-03-09, , Marrakech, , Ma, , Ma, , 1303, , tafela7t, , adresse1, , adresse_test3, , rabat-maroc, , 12323, , paris, , Ma, , +33, , 54564414, , +33, , 065644564, , CDS, , 1234534, , 2020-03-09, , KO, , TITRE INCORRECT, , , , N]
    Affichage des 4 dernières valeurs : 
     
     
     
    N
    MAJ dossier ...........AG0004
    La BD à été MAJ avec succés//par exemple ici il doit retourner : [KO ,TITRE INCORRECT, ,N]
    valeurs de la ligne[AG0005, , 78015, , MRE, , MME, , houari, , BK2, , 1990-02-02, , TETOUAN, , Ma, , Ma, , 2121, , Artisans*tailleurs,*couturiers*et*autres*artisans*de*la*confection*et*du*textile, , adresse12512, , adresse_test2, , tanger-maroc, , 20200, , venise, , DE, , +31, , 41414141, , +34, , 061231135, , CNI, , 626262, , 2020-02-07, , KO, , TITRE INCORRECT, , , , N]
    Affichage des 4 dernières valeurs : 
     
     
     
    N
    MAJ dossier ...........AG0005//par exemple ici il doit retourner : [KO ,TITRE INCORRECT, ,N]
    La BD à été MAJ avec succés
    valeurs de la ligne[AG0006, , 78015, , MRE, , MME, , rachid, , said, , 1983-02-02, , tanger, , MW, , MW, , 4771, , Assistants*techniques*de*l*imprimerie*et*de*l*édition, , adresse1sqdqsd5, , adresse_test1, , tanger-maroc, , 20230, , rome, , MW, , +31, , 654564141, , +31, , 061231136, , PAS, , 626252, , 2020-05-02, , OK, , TITRE CORRECT, , 780150012345842154212, , O]
    Affichage des 4 dernières valeurs : 
     
    780150012345842154212
     
    O
    MAJ dossier ...........AG0006//par exemple ici il doit retourner : [OK ,TITRE CORRECT,780150012345842154212,O]
    La BD à été MAJ avec succés
    et voila mon fichier de test en question:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    AG0001|;78015|;MRE|;MLE|;bendari|;mohammed|;1952-02-02|;eljadida|;Ma|;Ma|;4702|;Contrôleurs*laitiers,*inséminateurs*et*autres*agents*techniques*agricoles|;adresse15445qsd|;adresse_test6|;casablanca-maroc|;20200|;amiens|;Ma|;+33|;6545644141|;+33|;061231137|;CNI|;626262|;2020-04-02|;KO|;TITRE INCORRECT|;|;N
    AG0003|;78015|;MRE|;MLE|;benjeloun|;ahmed|;1986-02-02|;marrakech|;Ma|;Ma|;1102|;Maraîchers,*horticulteurs*sur*petite*exploitation|;adresse121881|;adresse_test5|;casablanca-maroc|;20200|;bordeaux|;Ma|;+33|;65444141|;+33|;052323212|;PAS|;626262|;2020-02-12|;KO|;TITRE INCORRECT|;|;N
    AG0002|;78015|;MRE|;M|;benanni|;fatima|;1980-02-02|;casablanca|;Ma|;Ma|;2105|;bmce|;paris-france|;adresse_test4|;casablanca-maroc|;30200|;paris|;FR|;+33|;65456444|;+33|;061231138|;CDS|;626262|;2020-06-02|;KO|;TITRE INCORRECT|;|;N
    AG0004|;78015|;MRE|;M|;client1|;hamid|;1967-03-09|;Marrakech|;Ma|;Ma|;1303|;tafela7t|;adresse1|;adresse_test3|;rabat-maroc|;12323|;paris|;Ma|;+33|;54564414|;+33|;065644564|;CDS|;1234534|;2020-03-09|;KO|;TITRE INCORRECT|;|;N
    AG0005|;78015|;MRE|;MME|;houari|;BK2|;1990-02-02|;TETOUAN|;Ma|;Ma|;2121|;Artisans*tailleurs,*couturiers*et*autres*artisans*de*la*confection*et*du*textile|;adresse12512|;adresse_test2|;tanger-maroc|;20200|;venise|;DE|;+31|;41414141|;+34|;061231135|;CNI|;626262|;2020-02-07|;KO|;TITRE INCORRECT|;|;N
    AG0006|;78015|;MRE|;MME|;rachid|;said|;1983-02-02|;tanger|;MW|;MW|;4771|;Assistants*techniques*de*l*imprimerie*et*de*l*édition|;adresse1sqdqsd5|;adresse_test1|;tanger-maroc|;20230|;rome|;MW|;+31|;654564141|;+31|;061231136|;PAS|;626252|;2020-05-02|;OK|;TITRE CORRECT|;780150012345842154212|;O
    Est ce que vous avez une visibilité sur ce problème .
    Partie CODE:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
       while ((line  = br.readLine()) != null) 
                {
                    String[] List = line.split("[|;]",-1);
     
                System.out.println("valeurs de la ligne"+Arrays.toString(List)); // affiche l'ensemble des valeurs de la ligne
                System.out.println("Affichage des 4 dernières valeurs : ");
                for(int index = List.length-4; index<List.length; index++) {
                            System.out.println(List[index]);
     
                        }
                         storeInDB(List[0], Arrays.copyOfRange(List,List.length-4,List.length));
                }
    Merci d'avance Mr JOEL.

    Bonne journée.

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Réponses: 2
    Dernier message: 06/10/2009, 23h41
  2. Réponses: 8
    Dernier message: 06/03/2008, 16h32
  3. Réponses: 3
    Dernier message: 10/05/2007, 14h12
  4. [DOM XML] Insertion données dans fichier XML avec PHP pour Flash ?
    Par ExSter dans le forum Bibliothèques et frameworks
    Réponses: 17
    Dernier message: 10/05/2006, 11h16
  5. [C#] problème avec l'insertion des données dans MySQL
    Par madica dans le forum Accès aux données
    Réponses: 7
    Dernier message: 08/11/2005, 13h27

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