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

[langage] aide pour un script pliz


Sujet :

Langage Perl

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 4
    Points : 1
    Points
    1
    Par défaut [langage] aide pour un script pliz
    bonjour, je dois rendre un script en perl pour le 24 mai, et j'ai franchement du mal, vu que j'en ai jamais fait, et que les cours était vraiment tout naze... j'aimerais faire un carnet d'adresse en perl.
    alors j'ai réussit à faire ça en cours:
    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
    #!/usr/bin/perl
    use CGI qw(:standard);
    use CGI::Carp qw(fatalsToBrowser);
    #projet
    print header; 
    print start_html,
    	"<body bgcolor=#FFFFCC text=#00CCCC><center><H1>CARNET D'ADRESSE<br><br><br></H1>";
    print start_form,
    	"<br><br><br>Nom: ",textfield('nom'),
            "<br><br>Prénom: ",textfield('prenom'),
    	"<br><br>Adresse: ",textfield('adresse'),
    	"<br><br>Ville: ",textfield('ville'),
    	"<br><br>Tel: ",textfield('tel'),
    	"<br><br>date de naissance (jj/mm/aa): ",textfield('date'),
    	"<br><br>adresse mail: ",textfield('mail'),
    	"<br><br>Citation: ",textfield('citation'),
    	"<br><br>\t\t\t",submit('oki douki');
    print end_form;
    if (param()) {
    if (param("pass1") ne param("pass2")){
    	print "<br>NO";          
    	} 
    	elsif (param("pass1") =~ /\s/){
    	print "<br>NO"; 
    	}
    	else{
    	print "<br>OK";
    	}
    }
    #!/usr/bin/perl
    use CGI qw(:standard);
    use CGI::Carp qw(fatalsToBrowser);
    #projet
    print header; 
    print start_html,
    	"<body bgcolor=#FFFFCC text=#00CCCC><center><H1>CARNET D'ADRESSE<br><br><br></H1>";
    print start_form,
    	"<br><br><br>Nom: ",textfield('nom'),
            "<br><br>Prénom: ",textfield('prenom'),
    	"<br><br>Adresse: ",textfield('adresse'),
    	"<br><br>Ville: ",textfield('ville'),
    	"<br><br>Tel: ",textfield('tel'),
    	"<br><br>date de naissance (jj/mm/aa): ",textfield('date'),
    	"<br><br>adresse mail: ",textfield('mail'),
    	"<br><br>Citation: ",textfield('citation'),
    	"<br><br>\t\t\t",submit('oki douki');
    print end_form;
    if (param()) {
    if (param("pass1") ne param("pass2")){
    	print "<br>NO";          
    	} 
    	elsif (param("pass1") =~ /\s/){
    	print "<br>NO"; 
    	}
    	else{
    	print "<br>OK";
    	}
    }
     
    if (param()) {
    	if (param("mail") =~ /@/){
    	print "<br>bon";          
    	} else {
    	print "<br>pas bien";
    	}
    }
     
    print end_html;
    if (param()) {
    	if (param("mail") =~ /@/){
    	print "<br>bon";          
    	} else {
    	print "<br>pas bien";
    	}
    }
     
    print end_html;
    voila, je crois que ça donne un bon aperçu de mon niveau

    J'ai donc cherché un exemple de script sur internet, et j'ai trouvé ç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
    #!/usr/local/bin/perl
     
    use CGI_Lite; 
     
    $cgi =new CGI_Lite; 
     
    %in = $cgi->parse_form_data; 
     
    print "Content-type: text/html\n\n";
     
     
    open(CARNET, ">>carnet.txt") or die("Impossible d'ouvrir le carnet");
     
    print "Entree ajoutee au carnet:<br>\n";
     
    print CARNET "$in{'nom'}\n";
    print "Nom : $in{'nom'}<br>\n";
    print CARNET "$in{'prenom'}\n";
    print "Prenom : $in{'prenom'}<br>\n";
    print CARNET "$in{'adresse'}\n";
    print "Adresse : $in{'adresse'}<br>\n";
    print CARNET "$in{'ville'}\n";
    print "Ville : $in{'ville'}<br>\n";
    print CARNET "$in{'tel'}\n";
    print "Tel : $in{'tel'}<p>\n";
    close CARNET;
    mais chez moi ça bug, enfin bon il y a l'idée, donc j'ai essayé de bidouiller avec les deux, mais franchement je galère. j'aimerais que les champs remplit du formulaire s'enregistre dans le carnet d'adresse après vérification du formulaire (genre c'est bien un adresse mail qui a été entré....)
    et en plus je peux bosser sur le script que de 12 à 14h à la fac. bref je suis pas mal dans la merde, alors si quelqu'un pouvait m'aider un tit peu, ça serait vraiment cool !!

    ciao

    biog

  2. #2
    Mr6
    Mr6 est déconnecté
    Membre éclairé

    Homme Profil pro
    Inscrit en
    Septembre 2004
    Messages
    607
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2004
    Messages : 607
    Points : 794
    Points
    794
    Par défaut
    Pour commencer, je te conseille de lire ceci.
    Ensuite, tu reprends tes scripts pour qu'ils ressemblent à ce qui est expliqué dans la doc, ca devrait déjà te permettre d'y voir plus clair !

    @+
    Mr6

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 4
    Points : 1
    Points
    1
    Par défaut
    sans vouloir trop abuser, j'voudrais savoir si je suis sur la bonne piste ou pas, parce qu'il me reste pas beaucoup de temps pour le faire... et franchement plus j'avance, plus j'suis pommé !

    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
    #!/usr/bin/perl
    use CGI qw(:standard);
    use CGI::Carp qw(fatalsToBrowser);
    #projet
    open(CARNET, ">>/home/etuweb6/public_html/perl/carnet.txt") or die("Impossible d'ouvrir le carnet"); 
    print header; 
    print start_html,
          start_form,
     
    	"<body bgcolor=#FFFFCC text=#00CCCC><center><H1>CARNET D'ADRESSE<br><br><br></H1>";
    print	"<br><br><br>Nom: $in{'nom'}",textfield('nom');
    		print CARNET "$in{'nom'}\n";
    print 	"<br><br>Prénom: $in{'prenom'}",textfield('prenom');
    		print CARNET "$in{'prenom'}\n"; 
    print	"<br><br>Adresse: $in{'adresse'}",textfield('adresse');
    		print CARNET "$in{'adresse'}\n"; 
    print	"<br><br>Ville: ",textfield('ville');
    		print CARNET "$in{'ville'}\n"; 
    print	"<br><br>Tel: ",textfield('tel');
    		print CARNET "$in{'tel'}\n"; 
    print	"<br><br>date de naissance (jj/mm/aa): ",textfield('date');
    		print CARNET "$in{'date'}\n"; 
    print	"<br><br>adresse mail: ",textfield('mail');
    		print CARNET "$in{'mail'}\n"; 
    print	"<br><br>Citation: ",textfield('citation');
    		print CARNET "$in{'citation'}\n"; 
    print	"<br><br>\t\t\t",submit('oki douki');
    print end_form;
     
    if (param()) {
    if (param("pass1") ne param("pass2")){
    	print "<br>NO";          
    	} 
    	elsif (param("pass1") =~ /\s/){
    	print "<br>NO"; 
    	}
    	else{
    	print "<br>OK";
    	}
    }
     
    if (param()) {
    	if (param("mail") =~ /@/){
    	print "<br>bon";          
    	} else {
    	print "<br>pas bien";
    	}
    }
     
    print end_html;
    close CARNET;
    le formulaire s'affiche, mais les données sont pas enregistré dans le fichier carnet.txt

  4. #4
    Membre régulier
    Inscrit en
    Décembre 2004
    Messages
    63
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 63
    Points : 74
    Points
    74
    Par défaut
    je crois que tu devrais separer le formulaire et son traitement pour le stockage dans le carnet, en mettant action dans le start_form
    par exemple pour recuperer les noms et prenoms et les afficher apres

    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
     
    #!/usr/bin/perl -w
    # cgi1bis.pl, cgi1.pl écrit en style fonction
    use CGI qw(:standard);
     
    print header,
    start_html('Exemple de formulaire crée par un script Perl',-bgcolor=>'white'),
    div ( {-align=>'center'}, h2('Bonjour, veuillez remplir ce petit formulaire')),
    start_form('post',"http://dell/cgi-bin/cgi2.pl"),
    "Votre prénom ", textfield('prenom','') ,
    br,
    "Votre age ", textfield('age','') ,
    p, submit('Valider'), reset('Annuler'),
    end_form(),
    end_html;
     
    ################### cgi2.pl ################
    Voici la page créée par le script cgi2.pl, chargée de récupérer les valeurs des paramètres envoyés par cgi1.pl
    ------------------------------------------------------
    #!/usr/bin/perl -w
    use CGI;
    $html = new CGI;
    print $html->header,
    $html->start_html(
        -title=>'Réponse',
        -bgcolor=>'white',
        -link=>'red'
        );
    # contexte liste
    # foreach $n ($html->param()) {
    # $v = $html->param($n);
    # print $n, " = ", $v, $html->br; }
    print "
     
    Votre prénom est : ", $html->param('prenom'), "
    " if defined($html->param(prenom)); print "Vous avez déclaré que votre age est : ", $html->param('age'), " ans" if defined($html->param(age)); print $html->end_html;
    [

  5. #5
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 4
    Points : 1
    Points
    1
    Par défaut
    holla, bonjour,
    On m'a passé un livre sur le perl en anglais, c'était bien sympathique !
    Mais y avait un exemple de carnet d'adresse, donc ça m'a bien aidé
    ça a tout de suite plus de gueule, mais c'est pas encore ça...
    il accepte pas certain truc, et celui ki m'aidait à disparut, donc si quelqu'un pouvait voir ce qui va pas, pour en finir avec ça, ça serait vraiment cool !!

    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
    287
    288
    289
    290
    291
    292
    293
    294
    295
    296
    297
    298
    299
    300
    301
    302
    303
    304
    305
    306
    307
    308
    309
    310
    311
    312
    313
    314
    315
    316
    317
    318
    319
    320
    321
    322
    323
    324
    325
    326
    327
    328
    329
    330
    331
    332
    333
    334
    335
    336
    337
    338
    339
    340
    341
    342
    343
    344
    345
    346
    347
    348
    349
    350
    351
    352
    353
    354
    355
    356
    357
    358
    359
    360
    361
    362
    363
    364
    365
    366
    367
    368
    369
    370
    371
    372
    373
    374
    375
    376
    377
    378
    379
    380
    381
    382
    383
    384
    385
    386
    387
    388
    389
    390
    391
    392
    393
    394
    395
    396
    397
    398
    399
    400
    401
    402
    403
    404
    405
    406
    407
    408
    409
    410
    411
    412
    413
    414
    415
    416
    417
    418
    419
    420
    421
    422
    423
    424
    425
    426
    427
    428
    429
    430
    431
    432
    433
    434
    435
    436
    437
    438
    439
    440
    441
    442
    443
    444
    445
    446
    447
    448
    449
    450
    451
    452
    453
    454
    455
    456
    457
    458
    459
    460
    461
    462
    463
    464
    465
    466
    467
    468
    469
    470
    471
    472
    473
    474
    475
    476
    477
    478
    479
    480
    481
    482
    483
    484
    485
    486
    487
    488
    489
    490
    491
    492
    493
    494
    495
    496
    497
    498
    499
    500
    501
    502
    503
    504
    505
    506
    507
    508
    509
    510
    511
    512
    513
    514
    515
    516
    517
    518
    519
    520
    521
    522
    523
    524
    525
    526
    527
    528
    529
    530
    531
    532
    533
    534
    535
    536
    537
    538
    539
    540
    541
    542
    543
    544
    545
    546
    547
    548
    549
    550
    551
    552
    553
    554
    555
    556
    557
    558
    559
    560
    561
    562
    563
    564
    565
    566
    567
    568
    569
    #!/usr/bin/perl
     
    use strict;
    use CGI qw(:standard);
    use CGI::Carp qw(fatalsToBrowser);
    use vars qw($DBH $CGI $TABLE @champ_nom @champ_description);
    open(CARNET, ">>/home/etuweb6/public_html/perl/carnet.txt") or die("Impossible d'ouvrir le carnet"); 
    #$DBH = DBI->connect("DBI:CSV:f_dir=/home/etuweb6/public_html/perl/carnet.txt") or die("Impossible d'ouvrir le carnet") . $DBI::errstr;
    @champ_nom= ("nom", "prenom", "adresse", "tel", "mail");
    @champ_description= ("nom", "prenom", "adresse", "tel", "mail");
    $TABLE = "carnet";
    $CGI=new CGI();
     
    if ($CGI->param( "submit_maintenance")) {
          maintenance($CGI);
        }
        elsif ($CGI->param( "submit_update")) {
              update ($CGI, $DBH);
        }
        elsif ($CGI->param( "submit_supp")) {
              supprimer ($CGI, $DBH);
        }
        elsif ($CGI->param( "submit_add")) {
              ajouter ($CGI, $DBH);
        }
        elsif ($CGI->param( "submit_question_pour_supp")) {
              questionsupp ($CGI);
        }
        elsif ($CGI->param( "submit_question_pour_up")) {
              questionup ($CGI, $DBH);
        }
        elsif ($CGI->param( "submit_questionsupp")) {
              resultatsupp ($CGI);
        }
        elsif ($CGI->param( "submit_questionup")) {
               resultatup ($CGI);
        }
        elsif ($CGI->param( "submit_entrer_adresse")) {
              entrernewadresse ($CGI);
        }
        elsif ($CGI->param( "submit_resultat")) {
              resultat ($CGI, $DBH);
        }
        else {
              carnet ($CGI);
       }
     
    sub carnet {
    my $cgi = shift;
    print $cgi->header();
     
    print qq`
    <HTML>
    <HEAD>
    <TITLE>Carnet d'adresse</TITLE>
    </HEAD>
    <body bgcolor=#FFFFCC text=#00CCCC>
    <center>
    <H1>CARNET D'ADRESSE<br><br><br></H1>
    <FORM METHOD=POST>
     
    <H3><STRONG>DESCRIPTION: </STRONG></H3>
    <TABLE>
    <TR>
    <TD ALIGN="RIGHT">Nom:</TD>
    <TD><INPUT TYPE="text" NAME="nom"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Prenom:</TD>
    <TD><INPUT TYPE="text" NAME="prenom"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Adresse:</TD>
    <TD><INPUT TYPE="text" NAME="adresse"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Tel:</TD>
    <TD><INPUT TYPE="text" NAME="tel"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Mail:</TD>
    <TD><INPUT TYPE="text" NAME="mail"></TD>
    </TR>
    </TABLE>
    <P>
    <INPUT TYPE="checkbox" NAME="controle">
           <STRONG> Remplir correctement </STRONG>
    <P>
    <INPUT TYPE="submit" name="submit_resultat" value="rechercher">
    <INPUT TYPE="submit" name="submit_maintenance" value="page de la maintenance">
    <INPUT TYPE="reset" value="actualiser">
    </FORM>
     
    <P><HR>
    </BODY></HTML>
    `;
     
    } #fin du carnet
     
     
    sub maintenance {
      my $cgi = shift;
      my $message = shift;
     
      if ($message) {
         $message = $message . "\n<HR>\n";
      }
     
      print $cgi->header();
     
      print qq`<HTML>
    <HEAD><TITLE> Maintenance du carnet d'adresse </TITLE></HEAD>
     
    <BODY BGCOLOR="FFFFFF">
    <CENTER>
    <H1>Maintenance du carnet d'adresse</H1>
    <HR>
    $message
    <P>
     
    <FORM METHOD=POST>
     
    <INPUT TYPE="SUBMIT" name="submit_entrer_adresse" value="nouvelle adresse">
    <INPUT TYPE="SUBMIT" name="submit_question_pour_up" value="mise à jour">
    <INPUT TYPE="SUBMIT" name="submit_question_pour_supp" value="effacer adresse">
    <INPUT TYPE="SUBMIT" name="submit_recherche" value="rechercher adresse">
     
    </FORM>
    </CENTER>
    <HR>
    </BODY></HTML>
    `;
     
    } #fin de la maintenance
     
    sub tout_les_resultats {
      my $cgi = shift;
      my $dbh = shift;
      my $op = shift;
     
      my $results = voirresultats ($cgi, $dbh);
     
      print $cgi->header();
     
      my $title;
      my $extra_column = "";
      my $form = "";
      my $center = "";
      if ($op eq "SEARCH") {
         $title = "résultat de la recherche";
         $center = "<CENTER>";
      }
       elsif ($op eq "UPDATE") {
       $title = "résultat pour l'update";
       $extra_column = "<TH>Update<TH>";
       $form = qq`<FORM METHOD="POST>`;
       }
         else  {
       $title = "résultat pour supprimer";
       $extra_column = "<TH>supprimer<TH>";
       $form = qq`<FORM METHOD="POST>`;
       }
     
       print qq`<HTML>
    <HEAD><TITLE>$title</TITLE></HEAD>
    <BODY BGCOLOR="WHITE">
    $center
    <H1>résultat de la recherche</H1>
    <HR>
    $form
    >TABLE BORDER=1>
    `;
    print "<TR>$extra_column"
          . join("/n", map("<TH>" . $_. "</TH>", @champ_description)) . "</TR>/n";
     
    my $row;
    foreach $row (@$results) {
            print "<TR>";
            if ($op eq "SEARCH") {
               print join("/n", map("<TD>" . $_. "</TD>", @$row));
            }
            elsif ($op eq "UPDATE") {
            print qq`\n<TD ALIGN="CENTER">
                  <INPUT TYPE="radio" NAME="update_critère" VALUE="`. join("|", @$row) . qq`"></TD>\n`;
            print join("\n", map("<TD>" . $_ . "</TD>", @$row));
            }
            else { #supprime
             print qq`\n<TD ALIGN="CENTER">
                  <INPUT TYPE="radio" NAME="supprimer_critère" VALUE="`. join("|", @$row) . qq`"></TD>\n`;
            print join("\n", map("<TD>" . $_ . "</TD>", @$row));
            }
            print "</TR>\n";
    }
     
     
    print qq"</TABLE>\n";
     
    if ($op eq "UPDATE") {
       my $tableau_adresse = presentationcarnet();
     
       print qq`$tableau_adresse
             <INPUT TYPE="submit" name="submit_update" value="sélectionner l'update">
             <INPUT TYPE="submit" name="submit_maintenance" value="page de la maintenance">
             </FORM>
             `;
     }
     elsif ($op eq "DELETE") {
     print qq`<P>
             <INPUT TYPE="submit" name="submit_supprime" value="sélectionner la suppression">
             <INPUT TYPE="submit" name="submit_maintenance" value="page de la maintenance">
             </FORM>
             `;
     }
     else {
            print "<CENTER>";
     }
     
    print "</BODY></HTML>\n";
     
     
     
    sub voirresultats {
      my $cgi = shift;
      my $dbh = shift;
     
      my @resultat_de_la_recherche;
      my $liste = join(",", @champ_nom);
      my $sql = "SELEST $liste FROM $TABLE";
     
      my %critere = ();
     
      my $champ;
      foreach $champ (@champ_nom) {
        if ($cgi->param($champ)) {
           $critere{$champ} = $cgi->param($champ);
        }
      }
      my $clause;
      if ($cgi->param('exact')) {
         $clause = join(" and ",
                   map ($_
                        . " = \""
                        . $critere{$_} . "\"", (keys %critere)));
      }
      else {
         $clause = join(" and ",
                   map ($_
                        . " like \"%"
                        . $critere{$_} . "\"", (keys %critere)));
      }
      $clause =~ /(.*)/;
      $clause = $1;
     
      $sq1 = $sq1 . " where " . $clause if ($clause);
     
      my $sth = $dbh->préparer($sq1) or die "impossible de préparer: " . $dbh->errstr();
      $sth->exécuter() or die "impossible d'exécuter: " . $sth->errstr();
     
      my @row;
      while (@row = $sth->reporter_tableau()) {
            my @case = @row;
            push(@results, \@case);
      }
      $sth->finit();
     
      return \@results;
     
    } #fin de voir les résultats
     
    sub resultat {
      my $cgi = shift;
      my $dbh = shift;
     
      tout_les_resultats($cgi,$dbh,"SEARCH");
     
    } #fin de resultat
     
    sub resultatup {
      my $cgi = shift;
      my $dbh = shift;
     
      tout_les_resultats($cgi,$dbh,"UPDATE");
     
    } #fin de resultatup
     
    sub resultatsupp {
      my $cgi = shift;
      my $dbh = shift;
     
      tout_les_resultats($cgi,$dbh,"DELETE");
     
    } #fin de resultatsupp
     
    sub ajouter {
      my $cgi = shift;
      my $dbh = shift;
     
      my @valeur_tableau = ();
      my @champ_manquant = ();
     
      my $champ;
      foreach $champ (@champ_nom) {
        my $valeur = $cgi->param($champ);
        if ($valeur) {
          push(@valeur_tableau, "'" . $valeur . "'");
        }
        else {
        push(@champ_manquant,$champ);
        }
      }
     
      my $liste_des_valeurs = "(" . join (",", @valeur_tableau) .")";
      $liste_des_valeurs =~ /(.*)/;
      $liste_des_valeurs = $1;
      my $liste = "(" . join (",", @champ_nom) .")";
     
      if (@champ_manquant > 0) {
         my $message_erreur = 
         qq`<STRONG>certains champs (`. join(",", @champ_manquant) . 
         qq`) ne sont pas remplis ! </STRONG>`;
      message_d_erreur ($cgi, $message_erreur);
     
      }
       else {
       my $sq1 = qq`INSERER DANS $TABLE $liste VALEURS $liste_des_valeurs`;
       my $sth = $dbh-> preparer($sq1) or die "impossible de préparer: " . $dbh->errstr();
       $sth->executer() or die "impossible d'exécuter: " . $sth->errstr();
       $sth->fin();
     
       maintenance ($cgi, "l'adresse a été ajouté");
     
       }
    } #fin de l'ajout d'adresse
     
    sub supprimer {
      my $cgi = shift;
      my $dbh = shift;
     
      my $critere_supprimer = $cgi->param("critere_supprimer");
      if (!$critere_supprimer) {
        my $message_erreur = "<STRONG>Vous n'avez rien sélectionné !</STRONG>";
        message_d_erreur ($cgi, $message_erreur);
     
      }
      else {
     
      my %critere = ();
     
      my @valeur_champ = split(/\|/, $critere_supprimer);
      for (1..@champ_nom) {
        $critere{$champ_nom[$_-1]} = $valeur_champ[$_-1];
        }
     
        my $clause;
        $clause = join(" and ",
                   map ($_
                        . " = \""
                        . $critere{$_} . "\"", (keys %critere)));
     
      $clause =~ /(.*)/;
      $clause = $1;
     
      my $sq1 = qq`SUPPRIME DE $TABLE $clause`;
      my $sth = $dbh-> preparer($sq1) or die "impossible de préparer: " . $dbh->errstr();
       $sth->executer() or die "impossible d'exécuter: " . $sth->errstr();
       $sth->fin();
     
       maintenance ($cgi, "l'adresse a été supprimé");
     
       }
    } #fin de la suppression d'adresse
     
    sub update {
      my $cgi = shift;
      my $dbh = shift;
     
      my $update_critere = $cgi->param("update_critere");
      if (!$update_critere) {
         my $message_erreur = "<STRONG>Vous n'avez rien sélectionné !</STRONG>";
        message_d_erreur ($cgi, $message_erreur);
     
      }
      else {
      my $logik = "";
      my %set = ();
      my $champ;
      foreach $champ (@champ_nom) {
        my $valeur = $cgi->param($champ);
        if ($valeur) {
          $set($champ) = $valeur;
        }
      }
      $logik = join(", ",
               map ($_ . "=\"". $set{$_} . "\"",
               (keys %set)));
      $logik = "SET $logik" if ($logik);
      $logik =~ /(.*)/;
      $logik = $1;
     
      my %critere =();
     
      my @valeur_champ = split(/\|/, $update_critere);
      for (1..@champ_nom) {
        $critere{$champ_nom[$_-1]} = $valeur_champ[$_-1];
        }
     
     
        my $clause;
        $clause = join(" and ",
                   map ($_
                        . " = \""
                        . $critere{$_} . "\"", (keys %critere)));
     
      $clause =~ /(.*)/;
      $clause = $1;
     
      my $sq1 = qq`mise à jour $TABLE $logik`. qq` $clause`;
      my $sth = $dbh-> preparer($sq1) or die "impossible de préparer: " . $dbh->errstr();
       $sth->executer() or die "impossible d'exécuter: " . $sth->errstr();
       $sth->fin();
     
       maintenance ($cgi, "l'adresse a été mise à jour");
     
       }
    } #fin de la mise à jour
     
    sub entrernewadresse {
      my $cgi = shift;
     
      actualiser ($cgi, "ADD");
     
    }#fin de l'entré de la nouvelle adresse
     
    sub questionup {
      my $cgi = shift;
     
      actualiser ($cgi, "UPDATE");
    }#fin de la mise à jour
     
    sub questionsupp {
      my $cgi = shift;
     
      actualiser ($cgi, "DELETE");
    }#fin de la suppression
     
    sub actualiser {
      my $cgi = shift;
      my $operation = shift;
     
      my $adresse_op = "Entrer une nouvelle adresse";
      $adresse_op = "Lancer une recherche pour supprimer" if($operation eq "DELETE");
      $adresse_op = "Lancer une recherche pour mettre à jour" if($operation eq "UPDATE");
     
      print $cgi->header();
     
    print qq`
    <HTML><HEAD>
    <TITLE>Maintenance du carnet d'adresse</TITLE>
    </HEAD>
     
    <BODY BGCOLOR="ffffff">
     
    <H1>$adresse_op</H1>
     
    <HR>
    <P>
    <FORM METHOD=POST>
    `;
     
    if ($operation eq "ADD") {
      print "Entrer les nouvelles info dans le formulaire en dessous\n";
    }
     elsif ($operation eq "UPDATE"){
     print "Choisissez le critère à modifier dans le formulaire en dessous\n";
    }
     else {
     print "Choisissez le critère à supprimer dans le formulaire en dessous\n";
    }
     
    my $carnet_adresse = voircarnet();
    print qq`
    <HR>
    <P>
    `;
    $carnet_adresse
     
    if ($operation eq "ADD") {
          print qq`
          <P>
          <INPUT TYPE="submit" NAME="submit_add" value="Ajouter cette adresse"<>p>
          `;
    }
     elsif ($operation eq "UPDATE") {
          print qq`
                <INPUT TYPE="checkbox" NAME="recherche">
          <STRONG>"Lancer la recherche"</STRONG>
          <P>
          <INPUT TYPE="submit" NAME="submit_critere_pour_update" value="critere à modifer">
          <p>
          `;
     }
      else {
             print qq`
          <INPUT TYPE="checkbox" NAME="recherche">
          <STRONG>"Lancer la recherche"</STRONG>
          <P>
          <INPUT TYPE="submit" NAME="submit_critere_à_supprimer" value="critere à supprimer">
          <p>
          `;
     }
     
     
    print qq`
    <INPUT TYPE="reset" value="actualiser_formulaire">
    </FORM>
    </BODY></HTML>
    `;
     
    }#fin de la mise à jour du carnet
     
    sub message_d_erreur {
      my$cgi = shift;
      my $message_erreur = shift;
     
     
      print $cgi->header();
     
      print qq`
    <HTML>
    <HEAD><TITLE>Message d'erreur</TITLE></HEAD>
    <BODY BGCOLOR="WHITE">
    <H1>Une erreur c'est produite</H1>
    <HR>
    $message_erreur
    </HR>
    </BODY>
    </HTML>
    `;
     
    } #fin des messages d'erreurs
     
    sub voircarnet {
     
    return qq`
    <TABLE>
    <TR>
    <TD ALIGN="RIGHT">Nom:</TD>
    <TD><INPUT TYPE="text" NAME="nom"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Prenom:</TD>
    <TD><INPUT TYPE="text" NAME="prenom"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Adresse:</TD>
    <TD><INPUT TYPE="text" NAME="adresse"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Tel:</TD>
    <TD><INPUT TYPE="text" NAME="tel"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Mail:</TD>
    <TD><INPUT TYPE="text" NAME="mail"></TD>
    </TR>
    </TABLE>
    `;
     
    }#fin du carnet d'adresse !!!!!!

  6. #6
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 4
    Points : 1
    Points
    1
    Par défaut
    Citation Envoyé par biog
    holla, bonjour,
    On m'a passé un livre sur le perl en anglais, c'était bien sympathique !
    Mais y avait un exemple de carnet d'adresse, donc ça m'a bien aidé
    ça a tout de suite plus de gueule, mais c'est pas encore ça...
    il accepte pas certain truc, et celui ki m'aidait à disparut, donc si quelqu'un pouvait voir ce qui va pas, pour en finir avec ça, ça serait vraiment cool !!

    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
    287
    288
    289
    290
    291
    292
    293
    294
    295
    296
    297
    298
    299
    300
    301
    302
    303
    304
    305
    306
    307
    308
    309
    310
    311
    312
    313
    314
    315
    316
    317
    318
    319
    320
    321
    322
    323
    324
    325
    326
    327
    328
    329
    330
    331
    332
    333
    334
    335
    336
    337
    338
    339
    340
    341
    342
    343
    344
    345
    346
    347
    348
    349
    350
    351
    352
    353
    354
    355
    356
    357
    358
    359
    360
    361
    362
    363
    364
    365
    366
    367
    368
    369
    370
    371
    372
    373
    374
    375
    376
    377
    378
    379
    380
    381
    382
    383
    384
    385
    386
    387
    388
    389
    390
    391
    392
    393
    394
    395
    396
    397
    398
    399
    400
    401
    402
    403
    404
    405
    406
    407
    408
    409
    410
    411
    412
    413
    414
    415
    416
    417
    418
    419
    420
    421
    422
    423
    424
    425
    426
    427
    428
    429
    430
    431
    432
    433
    434
    435
    436
    437
    438
    439
    440
    441
    442
    443
    444
    445
    446
    447
    448
    449
    450
    451
    452
    453
    454
    455
    456
    457
    458
    459
    460
    461
    462
    463
    464
    465
    466
    467
    468
    469
    470
    471
    472
    473
    474
    475
    476
    477
    478
    479
    480
    481
    482
    483
    484
    485
    486
    487
    488
    489
    490
    491
    492
    493
    494
    495
    496
    497
    498
    499
    500
    501
    502
    503
    504
    505
    506
    507
    508
    509
    510
    511
    512
    513
    514
    515
    516
    517
    518
    519
    520
    521
    522
    523
    524
    525
    526
    527
    528
    529
    530
    531
    532
    533
    534
    535
    536
    537
    538
    539
    540
    541
    542
    543
    544
    545
    546
    547
    548
    549
    550
    551
    552
    553
    554
    555
    556
    557
    558
    559
    560
    561
    562
    563
    564
    565
    566
    567
    568
    569
    #!/usr/bin/perl
     
    use strict;
    use CGI qw(:standard);
    use CGI::Carp qw(fatalsToBrowser);
    use vars qw($DBH $CGI $TABLE @champ_nom @champ_description);
    open(CARNET, ">>/home/etuweb6/public_html/perl/carnet.txt") or die("Impossible d'ouvrir le carnet"); 
    #$DBH = DBI->connect("DBI:CSV:f_dir=/home/etuweb6/public_html/perl/carnet.txt") or die("Impossible d'ouvrir le carnet") . $DBI::errstr;
    @champ_nom= ("nom", "prenom", "adresse", "tel", "mail");
    @champ_description= ("nom", "prenom", "adresse", "tel", "mail");
    $TABLE = "carnet";
    $CGI=new CGI();
     
    if ($CGI->param( "submit_maintenance")) {
          maintenance($CGI);
        }
        elsif ($CGI->param( "submit_update")) {
              update ($CGI, $DBH);
        }
        elsif ($CGI->param( "submit_supp")) {
              supprimer ($CGI, $DBH);
        }
        elsif ($CGI->param( "submit_add")) {
              ajouter ($CGI, $DBH);
        }
        elsif ($CGI->param( "submit_question_pour_supp")) {
              questionsupp ($CGI);
        }
        elsif ($CGI->param( "submit_question_pour_up")) {
              questionup ($CGI, $DBH);
        }
        elsif ($CGI->param( "submit_questionsupp")) {
              resultatsupp ($CGI);
        }
        elsif ($CGI->param( "submit_questionup")) {
               resultatup ($CGI);
        }
        elsif ($CGI->param( "submit_entrer_adresse")) {
              entrernewadresse ($CGI);
        }
        elsif ($CGI->param( "submit_resultat")) {
              resultat ($CGI, $DBH);
        }
        else {
              carnet ($CGI);
       }
     
    sub carnet {
    my $cgi = shift;
    print $cgi->header();
     
    print qq`
    <HTML>
    <HEAD>
    <TITLE>Carnet d'adresse</TITLE>
    </HEAD>
    <body bgcolor=#FFFFCC text=#00CCCC>
    <center>
    <H1>CARNET D'ADRESSE<br><br><br></H1>
    <FORM METHOD=POST>
     
    <H3><STRONG>DESCRIPTION: </STRONG></H3>
    <TABLE>
    <TR>
    <TD ALIGN="RIGHT">Nom:</TD>
    <TD><INPUT TYPE="text" NAME="nom"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Prenom:</TD>
    <TD><INPUT TYPE="text" NAME="prenom"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Adresse:</TD>
    <TD><INPUT TYPE="text" NAME="adresse"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Tel:</TD>
    <TD><INPUT TYPE="text" NAME="tel"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Mail:</TD>
    <TD><INPUT TYPE="text" NAME="mail"></TD>
    </TR>
    </TABLE>
    <P>
    <INPUT TYPE="checkbox" NAME="controle">
           <STRONG> Remplir correctement </STRONG>
    <P>
    <INPUT TYPE="submit" name="submit_resultat" value="rechercher">
    <INPUT TYPE="submit" name="submit_maintenance" value="page de la maintenance">
    <INPUT TYPE="reset" value="actualiser">
    </FORM>
     
    <P><HR>
    </BODY></HTML>
    `;
     
    } #fin du carnet
     
     
    sub maintenance {
      my $cgi = shift;
      my $message = shift;
     
      if ($message) {
         $message = $message . "\n<HR>\n";
      }
     
      print $cgi->header();
     
      print qq`<HTML>
    <HEAD><TITLE> Maintenance du carnet d'adresse </TITLE></HEAD>
     
    <BODY BGCOLOR="FFFFFF">
    <CENTER>
    <H1>Maintenance du carnet d'adresse</H1>
    <HR>
    $message
    <P>
     
    <FORM METHOD=POST>
     
    <INPUT TYPE="SUBMIT" name="submit_entrer_adresse" value="nouvelle adresse">
    <INPUT TYPE="SUBMIT" name="submit_question_pour_up" value="mise à jour">
    <INPUT TYPE="SUBMIT" name="submit_question_pour_supp" value="effacer adresse">
    <INPUT TYPE="SUBMIT" name="submit_recherche" value="rechercher adresse">
     
    </FORM>
    </CENTER>
    <HR>
    </BODY></HTML>
    `;
     
    } #fin de la maintenance
     
    sub tout_les_resultats {
      my $cgi = shift;
      my $dbh = shift;
      my $op = shift;
     
      my $results = voirresultats ($cgi, $dbh);
     
      print $cgi->header();
     
      my $title;
      my $extra_column = "";
      my $form = "";
      my $center = "";
      if ($op eq "SEARCH") {
         $title = "résultat de la recherche";
         $center = "<CENTER>";
      }
       elsif ($op eq "UPDATE") {
       $title = "résultat pour l'update";
       $extra_column = "<TH>Update<TH>";
       $form = qq`<FORM METHOD="POST>`;
       }
         else  {
       $title = "résultat pour supprimer";
       $extra_column = "<TH>supprimer<TH>";
       $form = qq`<FORM METHOD="POST>`;
       }
     
       print qq`<HTML>
    <HEAD><TITLE>$title</TITLE></HEAD>
    <BODY BGCOLOR="WHITE">
    $center
    <H1>résultat de la recherche</H1>
    <HR>
    $form
    >TABLE BORDER=1>
    `;
    print "<TR>$extra_column"
          . join("/n", map("<TH>" . $_. "</TH>", @champ_description)) . "</TR>/n";
     
    my $row;
    foreach $row (@$results) {
            print "<TR>";
            if ($op eq "SEARCH") {
               print join("/n", map("<TD>" . $_. "</TD>", @$row));
            }
            elsif ($op eq "UPDATE") {
            print qq`\n<TD ALIGN="CENTER">
                  <INPUT TYPE="radio" NAME="update_critère" VALUE="`. join("|", @$row) . qq`"></TD>\n`;
            print join("\n", map("<TD>" . $_ . "</TD>", @$row));
            }
            else { #supprime
             print qq`\n<TD ALIGN="CENTER">
                  <INPUT TYPE="radio" NAME="supprimer_critère" VALUE="`. join("|", @$row) . qq`"></TD>\n`;
            print join("\n", map("<TD>" . $_ . "</TD>", @$row));
            }
            print "</TR>\n";
    }
     
     
    print qq"</TABLE>\n";
     
    if ($op eq "UPDATE") {
       my $tableau_adresse = presentationcarnet();
     
       print qq`$tableau_adresse
             <INPUT TYPE="submit" name="submit_update" value="sélectionner l'update">
             <INPUT TYPE="submit" name="submit_maintenance" value="page de la maintenance">
             </FORM>
             `;
     }
     elsif ($op eq "DELETE") {
     print qq`<P>
             <INPUT TYPE="submit" name="submit_supprime" value="sélectionner la suppression">
             <INPUT TYPE="submit" name="submit_maintenance" value="page de la maintenance">
             </FORM>
             `;
     }
     else {
            print "<CENTER>";
     }
     
    print "</BODY></HTML>\n";
     
     
     
    sub voirresultats {
      my $cgi = shift;
      my $dbh = shift;
     
      my @resultat_de_la_recherche;
      my $liste = join(",", @champ_nom);
      my $sql = "SELEST $liste FROM $TABLE";
     
      my %critere = ();
     
      my $champ;
      foreach $champ (@champ_nom) {
        if ($cgi->param($champ)) {
           $critere{$champ} = $cgi->param($champ);
        }
      }
      my $clause;
      if ($cgi->param('exact')) {
         $clause = join(" and ",
                   map ($_
                        . " = \""
                        . $critere{$_} . "\"", (keys %critere)));
      }
      else {
         $clause = join(" and ",
                   map ($_
                        . " like \"%"
                        . $critere{$_} . "\"", (keys %critere)));
      }
      $clause =~ /(.*)/;
      $clause = $1;
     
      $sq1 = $sq1 . " where " . $clause if ($clause);
     
      my $sth = $dbh->préparer($sq1) or die "impossible de préparer: " . $dbh->errstr();
      $sth->exécuter() or die "impossible d'exécuter: " . $sth->errstr();
     
      my @row;
      while (@row = $sth->reporter_tableau()) {
            my @case = @row;
            push(@results, \@case);
      }
      $sth->finit();
     
      return \@results;
     
    } #fin de voir les résultats
     
    sub resultat {
      my $cgi = shift;
      my $dbh = shift;
     
      tout_les_resultats($cgi,$dbh,"SEARCH");
     
    } #fin de resultat
     
    sub resultatup {
      my $cgi = shift;
      my $dbh = shift;
     
      tout_les_resultats($cgi,$dbh,"UPDATE");
     
    } #fin de resultatup
     
    sub resultatsupp {
      my $cgi = shift;
      my $dbh = shift;
     
      tout_les_resultats($cgi,$dbh,"DELETE");
     
    } #fin de resultatsupp
     
    sub ajouter {
      my $cgi = shift;
      my $dbh = shift;
     
      my @valeur_tableau = ();
      my @champ_manquant = ();
     
      my $champ;
      foreach $champ (@champ_nom) {
        my $valeur = $cgi->param($champ);
        if ($valeur) {
          push(@valeur_tableau, "'" . $valeur . "'");
        }
        else {
        push(@champ_manquant,$champ);
        }
      }
     
      my $liste_des_valeurs = "(" . join (",", @valeur_tableau) .")";
      $liste_des_valeurs =~ /(.*)/;
      $liste_des_valeurs = $1;
      my $liste = "(" . join (",", @champ_nom) .")";
     
      if (@champ_manquant > 0) {
         my $message_erreur = 
         qq`<STRONG>certains champs (`. join(",", @champ_manquant) . 
         qq`) ne sont pas remplis ! </STRONG>`;
      message_d_erreur ($cgi, $message_erreur);
     
      }
       else {
       my $sq1 = qq`INSERER DANS $TABLE $liste VALEURS $liste_des_valeurs`;
       my $sth = $dbh-> preparer($sq1) or die "impossible de préparer: " . $dbh->errstr();
       $sth->executer() or die "impossible d'exécuter: " . $sth->errstr();
       $sth->fin();
     
       maintenance ($cgi, "l'adresse a été ajouté");
     
       }
    } #fin de l'ajout d'adresse
     
    sub supprimer {
      my $cgi = shift;
      my $dbh = shift;
     
      my $critere_supprimer = $cgi->param("critere_supprimer");
      if (!$critere_supprimer) {
        my $message_erreur = "<STRONG>Vous n'avez rien sélectionné !</STRONG>";
        message_d_erreur ($cgi, $message_erreur);
     
      }
      else {
     
      my %critere = ();
     
      my @valeur_champ = split(/\|/, $critere_supprimer);
      for (1..@champ_nom) {
        $critere{$champ_nom[$_-1]} = $valeur_champ[$_-1];
        }
     
        my $clause;
        $clause = join(" and ",
                   map ($_
                        . " = \""
                        . $critere{$_} . "\"", (keys %critere)));
     
      $clause =~ /(.*)/;
      $clause = $1;
     
      my $sq1 = qq`SUPPRIME DE $TABLE $clause`;
      my $sth = $dbh-> preparer($sq1) or die "impossible de préparer: " . $dbh->errstr();
       $sth->executer() or die "impossible d'exécuter: " . $sth->errstr();
       $sth->fin();
     
       maintenance ($cgi, "l'adresse a été supprimé");
     
       }
    } #fin de la suppression d'adresse
     
    sub update {
      my $cgi = shift;
      my $dbh = shift;
     
      my $update_critere = $cgi->param("update_critere");
      if (!$update_critere) {
         my $message_erreur = "<STRONG>Vous n'avez rien sélectionné !</STRONG>";
        message_d_erreur ($cgi, $message_erreur);
     
      }
      else {
      my $logik = "";
      my %set = ();
      my $champ;
      foreach $champ (@champ_nom) {
        my $valeur = $cgi->param($champ);
        if ($valeur) {
          $set($champ) = $valeur;
        }
      }
      $logik = join(", ",
               map ($_ . "=\"". $set{$_} . "\"",
               (keys %set)));
      $logik = "SET $logik" if ($logik);
      $logik =~ /(.*)/;
      $logik = $1;
     
      my %critere =();
     
      my @valeur_champ = split(/\|/, $update_critere);
      for (1..@champ_nom) {
        $critere{$champ_nom[$_-1]} = $valeur_champ[$_-1];
        }
     
     
        my $clause;
        $clause = join(" and ",
                   map ($_
                        . " = \""
                        . $critere{$_} . "\"", (keys %critere)));
     
      $clause =~ /(.*)/;
      $clause = $1;
     
      my $sq1 = qq`mise à jour $TABLE $logik`. qq` $clause`;
      my $sth = $dbh-> preparer($sq1) or die "impossible de préparer: " . $dbh->errstr();
       $sth->executer() or die "impossible d'exécuter: " . $sth->errstr();
       $sth->fin();
     
       maintenance ($cgi, "l'adresse a été mise à jour");
     
       }
    } #fin de la mise à jour
     
    sub entrernewadresse {
      my $cgi = shift;
     
      actualiser ($cgi, "ADD");
     
    }#fin de l'entré de la nouvelle adresse
     
    sub questionup {
      my $cgi = shift;
     
      actualiser ($cgi, "UPDATE");
    }#fin de la mise à jour
     
    sub questionsupp {
      my $cgi = shift;
     
      actualiser ($cgi, "DELETE");
    }#fin de la suppression
     
    sub actualiser {
      my $cgi = shift;
      my $operation = shift;
     
      my $adresse_op = "Entrer une nouvelle adresse";
      $adresse_op = "Lancer une recherche pour supprimer" if($operation eq "DELETE");
      $adresse_op = "Lancer une recherche pour mettre à jour" if($operation eq "UPDATE");
     
      print $cgi->header();
     
    print qq`
    <HTML><HEAD>
    <TITLE>Maintenance du carnet d'adresse</TITLE>
    </HEAD>
     
    <BODY BGCOLOR="ffffff">
     
    <H1>$adresse_op</H1>
     
    <HR>
    <P>
    <FORM METHOD=POST>
    `;
     
    if ($operation eq "ADD") {
      print "Entrer les nouvelles info dans le formulaire en dessous\n";
    }
     elsif ($operation eq "UPDATE"){
     print "Choisissez le critère à modifier dans le formulaire en dessous\n";
    }
     else {
     print "Choisissez le critère à supprimer dans le formulaire en dessous\n";
    }
     
    my $carnet_adresse = voircarnet();
    print qq`
    <HR>
    <P>
    `;
    $carnet_adresse
     
    if ($operation eq "ADD") {
          print qq`
          <P>
          <INPUT TYPE="submit" NAME="submit_add" value="Ajouter cette adresse"<>p>
          `;
    }
     elsif ($operation eq "UPDATE") {
          print qq`
                <INPUT TYPE="checkbox" NAME="recherche">
          <STRONG>"Lancer la recherche"</STRONG>
          <P>
          <INPUT TYPE="submit" NAME="submit_critere_pour_update" value="critere à modifer">
          <p>
          `;
     }
      else {
             print qq`
          <INPUT TYPE="checkbox" NAME="recherche">
          <STRONG>"Lancer la recherche"</STRONG>
          <P>
          <INPUT TYPE="submit" NAME="submit_critere_à_supprimer" value="critere à supprimer">
          <p>
          `;
     }
     
     
    print qq`
    <INPUT TYPE="reset" value="actualiser_formulaire">
    </FORM>
    </BODY></HTML>
    `;
     
    }#fin de la mise à jour du carnet
     
    sub message_d_erreur {
      my$cgi = shift;
      my $message_erreur = shift;
     
     
      print $cgi->header();
     
      print qq`
    <HTML>
    <HEAD><TITLE>Message d'erreur</TITLE></HEAD>
    <BODY BGCOLOR="WHITE">
    <H1>Une erreur c'est produite</H1>
    <HR>
    $message_erreur
    </HR>
    </BODY>
    </HTML>
    `;
     
    } #fin des messages d'erreurs
     
    sub voircarnet {
     
    return qq`
    <TABLE>
    <TR>
    <TD ALIGN="RIGHT">Nom:</TD>
    <TD><INPUT TYPE="text" NAME="nom"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Prenom:</TD>
    <TD><INPUT TYPE="text" NAME="prenom"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Adresse:</TD>
    <TD><INPUT TYPE="text" NAME="adresse"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Tel:</TD>
    <TD><INPUT TYPE="text" NAME="tel"></TD>
    </TR>
    <TR>
    <TD ALIGN="RIGHT">Mail:</TD>
    <TD><INPUT TYPE="text" NAME="mail"></TD>
    </TR>
    </TABLE>
    `;
     
    }#fin du carnet d'adresse !!!!!!

    et il me sort ça comme erreur :

    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
    <h1>Software error:</h1>
    <pre>Global symbol &quot;$s1&quot; requires explicit package name at rendu.pl line 254.
    Global symbol &quot;$s1&quot; requires explicit package name at rendu.pl line 254.
    Unrecognized character \xE9 at rendu.pl line 256.
    </pre>
    <p>
    For help, please send mail to this site's webmaster, giving this error message 
    and the time and date of the error.
     
    </p>
    [Tue May 17 12:56:25 2005] rendu.pl: Global symbol "$s1" requires explicit package name at rendu.pl line 254.
    [Tue May 17 12:56:25 2005] rendu.pl: Global symbol "$s1" requires explicit package name at rendu.pl line 254.
    [Tue May 17 12:56:25 2005] rendu.pl: Unrecognized character \xE9 at rendu.pl line 256.
    perl rendu.pl&
    [6] 23253
    [5]   Exit 255                perl rendu.pl

  7. #7
    Membre actif Avatar de Gamdwin
    Inscrit en
    Avril 2005
    Messages
    186
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 186
    Points : 207
    Points
    207
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $sq1 = $sq1 . " where " . $clause if ($clause);
     
    =>
    test.pl: Global symbol "$sq1" requires explicit package name at test.pl line 254.
    Si j'ai bien lu le script, je pense que tu voulais écrire :
    et non :
    De plus tu peux utiliser l'opérateur de concaténation ".=" :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql .= " where $clause" if ($clause ne "");




    Ensuite, ligne 256 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    my $sth = $dbh->préparer($sq1) or die "impossible de préparer: " . $dbh->errstr();
     
    => Unrecognized character \351 at test.pl line 256.

    D'où tu sors ce "préparer()", avec un accent en plus ?
    Et puis pour le module DBI, utilise la chaîne $DBI::errstr plutôt.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    my $sth = $dbh->prepare($sql) or die $DBI::errstr;

    Pareil pour la ligne suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sth->exécuter() or die "impossible d'exécuter: " . $sth->errstr();
    =>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sth->execute() or die $DBI::errstr;
    En plus ce sont des fonctions du module DBI ça, tu l'intègres où ?!
    Y a bien une ligne commentée pour se connecter, mais le module n'est intégré nul part.

    Bref, corriger toutes les erreurs de syntaxe/recopie/pompage avant de soumettre le code, pas envie de faire ton boulot à ta place.
    Essaie d'indenter le code, mettre ça au propre, quitte à séparer les sub dans des fichiers à part pour y voir plus clair, parce que là, comme ça, j'en perds mon latin.

Discussions similaires

  1. [MySQL] Aide pour un script utilisant foreach
    Par nicoreims dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 09/08/2006, 16h36
  2. Besoin d'aide pour un script shell
    Par lecharcutierdelinux dans le forum Linux
    Réponses: 5
    Dernier message: 20/05/2006, 10h36
  3. aide pour un script javascript
    Par speedylol dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 22/03/2006, 14h28
  4. [Tableaux] aide pour un script
    Par jim1 dans le forum Langage
    Réponses: 3
    Dernier message: 22/01/2006, 20h48
  5. [langage] Quel langage utiliser pour un script de CHAT ?
    Par Manu0086 dans le forum Général Conception Web
    Réponses: 15
    Dernier message: 11/11/2005, 19h14

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