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

PHP & Base de données Discussion :

Reperer une cellule vide


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Janvier 2007
    Messages
    439
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 439
    Par défaut Reperer une cellule vide
    Bonjour

    je vous ecris car je suis entrain de mettre en place sur un site un planning de gestion de rendez vous, avec prise de rendez vous

    dans la partie utilisateur je voudrais donc mettre le planning et quand j'ai une date de libre,

    de reperer les cellules vides, et d'y mettre libre a la place d'autres informations.

    je vous montres toutes les pages du code si vous pouvez m'aider svp.

    Planning.php
    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
    <?php
    class Planning {
    private $joursFr = Array(0=>'Dimanche', 1=>'Lundi', 2=>'Mardi', 3=>'Mercredi', 4=>'Jeudi', 5=>'Vendredi', 6=>'Samedi');
     
    private $jourDebut; // jour de début du planning (0 à 6)
    private $jourFin; // jour de fin du planning
     
    private $heureDebut; // heure de début de chaque jour (en minutes)
    private $heureFin; // heure de fin de chaque jour (en minutes)
     
    private $pas; // durée d'une case (en minutes)
    private $minutesKeys;
     
    private $contenu; // contenu général du planning (tableau de PlanningCellule)
     
    private $tabSemaine; // stockage des données (tableau initialisé avec des cellules vides)
     
    const htmlSpace = '&nbsp;';
    const htmlEmptyCell = '<td>&nbsp;</td>';
    const htmlCellOpen = '<td>';
    const htmlCellClose = '</td>';
    const htmlRowOpen = '<tr>';
    const htmlRowClose = '</tr>';
    const htmlTableOpen = '<table class="tabPlanning">';
    const htmlTableClose = '</table>';
     
    const separateurHeure = 'h';
     
    public function __construct($jourDebut=1, $jourFin=5, $heureDebut=540, $heureFin=1260, $pas=30, $contenu = Array()){
    $this->jourDebut = $jourDebut;
    $this->jourFin = $jourFin;
    $this->heureDebut = $heureDebut;
    $this->heureFin = $heureFin;
    $this->pas = $pas;
    $this->contenu = $contenu;
     
    $this->initTableauSemaine($this->contenu);
    // $this->debugPHPArrays();
    $this->insererContenus($contenu);
    }
     
    /**
    * Génère un tableau dont les clés sont les heures de début de chaque case (en minutes)
    * Serviront à identifier facilement chaque case du planning
    * @return unknown_type
    */
    private function genererMinutesKeys() {
    $keys = Array();
    for ($key=$this->heureDebut; $key<=$this->heureFin; $key+=$this->pas) {
    $keys[] = $key;
    }
    $this->keys = $keys;
    return $keys;
    }
     
    /**
    * Génère un tableau correspondant à un jour
    * @return unknown_type
    */
    private function initTableauJour() {
    if ($this->pas != 0) {
    $numCells = ($this->heureDebut - $this->heureFin) / $this->pas;
    } else {
    echo 'pas == 0 !!';
    }
    $keys = $this->genererMinutesKeys();
    $tabJour = array_fill_keys($keys, self::htmlEmptyCell);
    return $tabJour;
    }
     
    private function initTableauSemaine() {
    $this->tabSemaine = Array();
    $tabJour = $this->initTableauJour();
    for($i=$this->jourDebut; $i<=$this->jourFin; $i++) {
    $this->tabSemaine[$i] = $tabJour;
    }
    }
     
    private function getNumeroCellule($minutesDebut, $minutesFin) {
    return ($minutesFin - $minutesDebut) / $this->pas;
    }
     
    /**
    * Insère tous les contenus de cellulés envoyés
    * @param $contenuPlanning
    * @return unknown_type
    */
    private function insererContenus($contenuPlanning) {
    foreach ($contenuPlanning as $contenuCellule) {
    $this->insererContenu($contenuCellule);
    }
    }
     
    /**
    * Insère le contenu d'une cellule précise
    * @param $contenuCellule
    * @return unknown_type
    */
    private function insererContenu($contenuCellule) {
    // ajout de la cellule fusionnée
    $duree = $this->getNumeroCellule($contenuCellule->heureDebut, $contenuCellule->heureFin);
    $contenu = $contenuCellule->contenu.'<br />';
    $contenu .= $this->convertMinutesEnHeuresMinutes($contenuCellule->heureDebut);
    $contenu .= ' - '.$this->convertMinutesEnHeuresMinutes($contenuCellule->heureFin);
     
    $this->tabSemaine[$contenuCellule->numJour][$contenuCellule->heureDebut] = $this->genererCelluleHTML($contenu, $duree, '', $contenuCellule->bgColor);
     
    // suppression du contenu suivant
    $key = $contenuCellule->heureDebut;
    for ($cpt = $duree-1; $cpt>0; $cpt--) {
    $key += $this->pas;
    $this->tabSemaine[$contenuCellule->numJour][$key] = '';
    }
    }
     
    /* Affichage */
    public function debugPHPArrays() {
    echo '<pre>';
    print_r($this->tabSemaine);
    echo '</pre>';
    }
     
    public function genererHtmlTable() {
    $htmlTable = self::htmlTableOpen;
     
    $htmlTable .= $this->genererBandeauJours();
     
    $key = $this->heureDebut;
    $keyEnd = $this->heureFin;
    for ($key; $key <= $keyEnd; $key+=$this->pas) {
    $htmlTable .= self::htmlRowOpen;
    $htmlTable .= '<td class="cellHour">'.$this->convertMinutesEnHeuresMinutes($key).'</td>';
    foreach ($this->tabSemaine as $tabHeures) {
    $htmlTable .= $tabHeures[$key];
    }
    $htmlTable .= self::htmlRowClose;
    }
     
    $htmlTable .= self::htmlTableClose;
    return $htmlTable;
    }
     
    public function afficherHtmlTable() {
    echo $this->genererHtmlTable();
    }
     
    private function genererBandeauJours() {
    $daysLine = self::htmlRowOpen;
    $daysLine .= $this->genererCelluleHTML(self::htmlSpace);
    $day = $this->jourDebut;
    while ($day <= $this->jourFin) {
    $daysLine .= $this->genererCelluleHTML($this->jourFr($day), '', 'cellDay');
    $day++;
    }
    $daysLine .= self::htmlRowClose;
    return $daysLine;
    }
     
    /**
    * Génère une ligne HTML contenant le libellé des jours utilisés dans le planning
    * @param $contenuCellule
    * @param $colspan
    * @param $class
    * @param $bgColor
    * @return unknown_type
    */
    private function genererCelluleHTML($contenuCellule, $colspan = '', $class = '', $bgColor = '') {
    $celluleHTML = '<td';
    if (!empty($colspan))
    $celluleHTML .= ' rowspan="'.$colspan.'"';
    if (!empty($class))
    $celluleHTML .= ' class="'.$class.'"';
    if (!empty($bgColor))
    $celluleHTML .= ' bgcolor="'.$bgColor.'"';
    $celluleHTML .= '/>';
    $celluleHTML .= $contenuCellule;
    $celluleHTML .= '</td>';
    return $celluleHTML;
    }
     
    /**
    * Renvoie le libellé d'un jour en Français
    * @param $dayNum
    * @return unknown_type
    */
    private function jourFr($dayNum) {
    return $this->joursFr[$dayNum];
    }
     
    private function convertMinutesEnHeuresMinutes($minutes) {
    $heure = floor($minutes / 60);
    $minutes = ($minutes % 60);
    $minutes = str_pad($minutes, 2, '0', STR_PAD_LEFT);
    return ($heure. self::separateurHeure .$minutes);
    }
    }
    ?>

    PlanningMapper.php
    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
    <?php
    class Planning {
    private $joursFr = Array(0=>'Dimanche', 1=>'Lundi', 2=>'Mardi', 3=>'Mercredi', 4=>'Jeudi', 5=>'Vendredi', 6=>'Samedi');
     
    private $jourDebut; // jour de début du planning (0 à 6)
    private $jourFin; // jour de fin du planning
     
    private $heureDebut; // heure de début de chaque jour (en minutes)
    private $heureFin; // heure de fin de chaque jour (en minutes)
     
    private $pas; // durée d'une case (en minutes)
    private $minutesKeys;
     
    private $contenu; // contenu général du planning (tableau de PlanningCellule)
     
    private $tabSemaine; // stockage des données (tableau initialisé avec des cellules vides)
     
    const htmlSpace = '&nbsp;';
    const htmlEmptyCell = '<td>&nbsp;</td>';
    const htmlCellOpen = '<td>';
    const htmlCellClose = '</td>';
    const htmlRowOpen = '<tr>';
    const htmlRowClose = '</tr>';
    const htmlTableOpen = '<table class="tabPlanning">';
    const htmlTableClose = '</table>';
     
    const separateurHeure = 'h';
     
    public function __construct($jourDebut=1, $jourFin=5, $heureDebut=540, $heureFin=1260, $pas=30, $contenu = Array()){
    $this->jourDebut = $jourDebut;
    $this->jourFin = $jourFin;
    $this->heureDebut = $heureDebut;
    $this->heureFin = $heureFin;
    $this->pas = $pas;
    $this->contenu = $contenu;
     
    $this->initTableauSemaine($this->contenu);
    // $this->debugPHPArrays();
    $this->insererContenus($contenu);
    }
     
    /**
    * Génère un tableau dont les clés sont les heures de début de chaque case (en minutes)
    * Serviront à identifier facilement chaque case du planning
    * @return unknown_type
    */
    private function genererMinutesKeys() {
    $keys = Array();
    for ($key=$this->heureDebut; $key<=$this->heureFin; $key+=$this->pas) {
    $keys[] = $key;
    }
    $this->keys = $keys;
    return $keys;
    }
     
    /**
    * Génère un tableau correspondant à un jour
    * @return unknown_type
    */
    private function initTableauJour() {
    if ($this->pas != 0) {
    $numCells = ($this->heureDebut - $this->heureFin) / $this->pas;
    } else {
    echo 'pas == 0 !!';
    }
    $keys = $this->genererMinutesKeys();
    $tabJour = array_fill_keys($keys, self::htmlEmptyCell);
    return $tabJour;
    }
     
    private function initTableauSemaine() {
    $this->tabSemaine = Array();
    $tabJour = $this->initTableauJour();
    for($i=$this->jourDebut; $i<=$this->jourFin; $i++) {
    $this->tabSemaine[$i] = $tabJour;
    }
    }
     
    private function getNumeroCellule($minutesDebut, $minutesFin) {
    return ($minutesFin - $minutesDebut) / $this->pas;
    }
     
    /**
    * Insère tous les contenus de cellulés envoyés
    * @param $contenuPlanning
    * @return unknown_type
    */
    private function insererContenus($contenuPlanning) {
    foreach ($contenuPlanning as $contenuCellule) {
    $this->insererContenu($contenuCellule);
    }
    }
     
    /**
    * Insère le contenu d'une cellule précise
    * @param $contenuCellule
    * @return unknown_type
    */
    private function insererContenu($contenuCellule) {
    // ajout de la cellule fusionnée
    $duree = $this->getNumeroCellule($contenuCellule->heureDebut, $contenuCellule->heureFin);
    $contenu = $contenuCellule->contenu.'<br />';
    $contenu .= $this->convertMinutesEnHeuresMinutes($contenuCellule->heureDebut);
    $contenu .= ' - '.$this->convertMinutesEnHeuresMinutes($contenuCellule->heureFin);
     
    $this->tabSemaine[$contenuCellule->numJour][$contenuCellule->heureDebut] = $this->genererCelluleHTML($contenu, $duree, '', $contenuCellule->bgColor);
     
    // suppression du contenu suivant
    $key = $contenuCellule->heureDebut;
    for ($cpt = $duree-1; $cpt>0; $cpt--) {
    $key += $this->pas;
    $this->tabSemaine[$contenuCellule->numJour][$key] = '';
    }
    }
     
    /* Affichage */
    public function debugPHPArrays() {
    echo '<pre>';
    print_r($this->tabSemaine);
    echo '</pre>';
    }
     
    public function genererHtmlTable() {
    $htmlTable = self::htmlTableOpen;
     
    $htmlTable .= $this->genererBandeauJours();
     
    $key = $this->heureDebut;
    $keyEnd = $this->heureFin;
    for ($key; $key <= $keyEnd; $key+=$this->pas) {
    $htmlTable .= self::htmlRowOpen;
    $htmlTable .= '<td class="cellHour">'.$this->convertMinutesEnHeuresMinutes($key).'</td>';
    foreach ($this->tabSemaine as $tabHeures) {
    $htmlTable .= $tabHeures[$key];
    }
    $htmlTable .= self::htmlRowClose;
    }
     
    $htmlTable .= self::htmlTableClose;
    return $htmlTable;
    }
     
    public function afficherHtmlTable() {
    echo $this->genererHtmlTable();
    }
     
    private function genererBandeauJours() {
    $daysLine = self::htmlRowOpen;
    $daysLine .= $this->genererCelluleHTML(self::htmlSpace);
    $day = $this->jourDebut;
    while ($day <= $this->jourFin) {
    $daysLine .= $this->genererCelluleHTML($this->jourFr($day), '', 'cellDay');
    $day++;
    }
    $daysLine .= self::htmlRowClose;
    return $daysLine;
    }
     
    /**
    * Génère une ligne HTML contenant le libellé des jours utilisés dans le planning
    * @param $contenuCellule
    * @param $colspan
    * @param $class
    * @param $bgColor
    * @return unknown_type
    */
    private function genererCelluleHTML($contenuCellule, $colspan = '', $class = '', $bgColor = '') {
    $celluleHTML = '<td';
    if (!empty($colspan))
    $celluleHTML .= ' rowspan="'.$colspan.'"';
    if (!empty($class))
    $celluleHTML .= ' class="'.$class.'"';
    if (!empty($bgColor))
    $celluleHTML .= ' bgcolor="'.$bgColor.'"';
    $celluleHTML .= '/>';
    $celluleHTML .= $contenuCellule;
    $celluleHTML .= '</td>';
    return $celluleHTML;
    }
     
    /**
    * Renvoie le libellé d'un jour en Français
    * @param $dayNum
    * @return unknown_type
    */
    private function jourFr($dayNum) {
    return $this->joursFr[$dayNum];
    }
     
    private function convertMinutesEnHeuresMinutes($minutes) {
    $heure = floor($minutes / 60);
    $minutes = ($minutes % 60);
    $minutes = str_pad($minutes, 2, '0', STR_PAD_LEFT);
    return ($heure. self::separateurHeure .$minutes);
    }
    }
    ?>
    PlanningCellule.php
    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
    <?php
    class PlanningCellule {
    private $data;
     
    public function __construct($numJour, $heureDebut, $heureFin, $bgColor, $contenu) {
    $this->numJour = $numJour;
    $this->heureDebut = $heureDebut;
    $this->heureFin = $heureFin;
    $this->bgColor = $bgColor;
    $this->contenu = $contenu;
    }
     
    public function __set($name, $value) {
    if ($name == 'heureDebut' || $name == 'heureFin') {
    $tabHeure = explode(':', $value);
    $value = (int)$tabHeure[0];
    if ($tabHeure[1] == 30)
    $value += 0.5;
    $value = $value*60;
    }
    $this->data[$name] = $value;
    }
     
    public function __get($name) {
    if (array_key_exists($name, $this->data)) {
    return $this->data[$name];
    }
     
    $trace = debug_backtrace();
    trigger_error(
    'Propriété non-définie via __get(): ' . $name .
    ' dans ' . $trace[0]['file'] .
    ' à la ligne ' . $trace[0]['line'],
    E_USER_NOTICE);
    return null;
    }
     
    public function __toString() {
    $str = 'heure début : '.$this->heureDebut."<br />\n";
    $str .= 'heure fin : '.$this->heureFin."<br />\n";
    $str .= 'couleur : '.$this->bgColor."<br />\n";
    $str .= 'contenu : '.$this->contenu."<br />\n";
    return $str;
    }
    }
    ?>
    et enfin index_planning.php
    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
    <html>
    <head>
    <title>Démo planning dynamique</title>
    <link rel="stylesheet" type="text/css" media="screen" href="planning.css" />
    <body>
    <div id="planning">
    <?php
    include('Planning.php');
    include('PlanningCellule.php');
    include('PlanningMapper.php');
     
    $contenusCellules[] = new PlanningCellule(1,'17:30:00','19:00:00','#008000','<b>Zeus</b><br />B1/1');
    $contenusCellules[] = new PlanningCellule(1,'19:30:00','21:00:00','#7CCAF4','<b>Ryle</b><br />A2');
    $contenusCellules[] = new PlanningCellule(2,'12:30:00','14:00:00','#7CCAF4','<b>Mère-Térésa</b><br />A2');
    $contenusCellules[] = new PlanningCellule(2,'14:00:00','15:30:00','#314E8C','<b>Truc</b><br />A1');
    $contenusCellules[] = new PlanningCellule(2,'16:00:00','17:30:00','#314E8C','<b>Albat</b><br />A1');
    $contenusCellules[] = new PlanningCellule(2,'17:30:00','19:00:00','#C080C0','<b>Calimero</b><br />B3');
    $contenusCellules[] = new PlanningCellule(3,'10:30:00','12:00:00','#800080','<b>Damien</b><br />B2');
    $contenusCellules[] = new PlanningCellule(3,'13:00:00','14:30:00','#314E8C','<b>Cobaye</b><br />A1');
    $contenusCellules[] = new PlanningCellule(3,'14:30:00','16:00:00','#80C080','<b>Moosh</b><br />B1/2');
    $contenusCellules[] = new PlanningCellule(3,'16:00:00','17:30:00','#008000','<b>@rthur</b><br />B1/1');
    $contenusCellules[] = new PlanningCellule(3,'18:30:00','20:00:00','#80C080','<b>Dunbar</b><br />B1/2');
    $contenusCellules[] = new PlanningCellule(3,'20:00:00','21:30:00','#7CCAF4','<b>Ryle</b><br />A2');
    $contenusCellules[] = new PlanningCellule(4,'11:00:00','12:30:00','#314E8C','<b>AB</b><br />A1');
    $contenusCellules[] = new PlanningCellule(4,'14:00:00','15:30:00','#7CCAF4','<b>Hywan</b><br />A2');
    $contenusCellules[] = new PlanningCellule(4,'17:00:00','18:30:00','#7CCAF4','<b>Sekiltoyai</b><br />A2');
    $contenusCellules[] = new PlanningCellule(4,'18:30:00','20:00:00','#800080','<b>Genova</b><br />B2');
    $contenusCellules[] = new PlanningCellule(4,'20:00:00','21:30:00','#008000','<b>Ouckileou</b><br />B1/1');
    $contenusCellules[] = new PlanningCellule(5,'09:00:00','10:30:00','#314E8C','<b>Nagol</b><br />A1');
    $contenusCellules[] = new PlanningCellule(5,'18:00:00','19:30:00','#80C080','<b>Fab</b><br />B1/2');
    $contenusCellules[] = new PlanningCellule(6,'10:30:00','12:00:00','#80C080','<b>Naholyr</b><br />B1/2');
     
     
     
     
    $planning = new Planning(1, 6, 540, 1260, 30, $contenusCellules);
    $planning->afficherHtmlTable();
    ?>

  2. #2
    Membre chevronné Avatar de 01001111
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2009
    Messages
    319
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Loire (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2009
    Messages : 319
    Par défaut
    Normalement il suffit que tu testes la variable suivante:
    qui est dans la fonction genererCelluleHTML() dans PlanningMapper
    si le contenu de cette variable est celui attendu pour une cellule vide, tu le remplaces par "Libre".

    ou alors la variable $contenuCellule dans insererContenu() toujours dans la même classe, peut être testée et remplacée par "Libre".
    C'est d'ailleurs mieux car c'est plus en amont.

    Quelques petits conseils: si tu évites les fonctions dont le nom diffère d'un s uniquement ainsi que les mêmes noms de fonctions dans deux classes différentes, ça facilitera ta relecture du code.

Discussions similaires

  1. comment faire une cellule vide ?
    Par filigane dans le forum Excel
    Réponses: 13
    Dernier message: 03/08/2007, 11h12
  2. [Jxl] Lecture d'une cellule vide
    Par Aerofly dans le forum Documents
    Réponses: 1
    Dernier message: 08/02/2007, 11h24
  3. sauter un chapitre de code quand une cellule vide
    Par mimic44 dans le forum Access
    Réponses: 7
    Dernier message: 09/01/2007, 09h09
  4. Réponses: 3
    Dernier message: 06/12/2006, 10h01
  5. Mettre un "0" à là place d'une cellule vide.
    Par P'tit Lio dans le forum Access
    Réponses: 22
    Dernier message: 24/07/2006, 14h19

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