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

ASP.NET Discussion :

calculs sur une cellule d'un gridview


Sujet :

ASP.NET

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    367
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 367
    Par défaut calculs sur une cellule d'un gridview
    Bonjour

    Est-ce possible de remplir un gridview dont le contenu de la cellule serait un calcul avec des chiffres issus de deux tables différentes ?
    Exemple premier chiffre = Nbre.Table1, le 2éme Nbre.Table2, le résultat à afficher dans le cellule = (Nbre.Table2/Nbre.Table1)*100
    Merci pour vos réponses
    JCM

  2. #2
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2007
    Messages
    693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2007
    Messages : 693
    Par défaut
    Bonjour,

    Ce n'est pas possible sur la datagridview mais c'est faisable sur la datatable (si biensur tu utilises une datatabe comme source de données)

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    367
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 367
    Par défaut
    Je ne connais pas le DataTable, j'ai essayé d'en créer un, mais je ne vois pas bien comment cela se présente à l'affichage : comme un gridview ?
    Est-ce qu'il serait plus simple d'ajouter dynamiquement une ligne au gridview, de procéder aux calculs par une procédure et d'imputer le résultat à la cellule de cette nouvelle ligne
    JCM

  4. #4
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2007
    Messages
    693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2007
    Messages : 693
    Par défaut
    J'ai été un peu trop vite.

    Donne nous plus de détail sur ce que tu as fait.

    Tu utilises une gridview pour afficher tes résultats, comment communiques-tu les résultats (données) à ta gridview ?

    Edit : une datatable n'a pas de représentation graphique, c'est un objet conteneur de données.

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    367
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 367
    Par défaut
    Par une requete SQL et DataBind

  6. #6
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2007
    Messages
    693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2007
    Messages : 693
    Par défaut
    Et avec du code ?

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    367
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 367
    Par défaut
    Je n'ai pas fait de code car tu m'avais dit que c'était pas possible
    Et très honnètement je ne sais pas écrire ce type de requete

  8. #8
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2007
    Messages
    693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2007
    Messages : 693
    Par défaut
    Je disais du code détaillant ta récupération de données et le binding !

  9. #9
    Membre émérite Avatar de Ramajb
    Homme Profil pro
    ----------------------------
    Inscrit en
    Septembre 2007
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ----------------------------

    Informations forums :
    Inscription : Septembre 2007
    Messages : 476
    Par défaut
    Citation Envoyé par JCMANSION Voir le message
    Bonjour

    Est-ce possible de remplir un gridview dont le contenu de la cellule serait un calcul avec des chiffres issus de deux tables différentes ?
    Exemple premier chiffre = Nbre.Table1, le 2éme Nbre.Table2, le résultat à afficher dans le cellule = (Nbre.Table2/Nbre.Table1)*100
    Merci pour vos réponses
    JCM
    C'est possible. Mais avant de te donner quelques idées, il faut que tu nous dise s'il y a une relation entre les deux table ou pas.

  10. #10
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    367
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 367
    Par défaut
    Oui, elles ont un champs commun Tab1.designe et Tab2.designe
    Est-cela ta question ?

  11. #11
    Membre émérite Avatar de Ramajb
    Homme Profil pro
    ----------------------------
    Inscrit en
    Septembre 2007
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ----------------------------

    Informations forums :
    Inscription : Septembre 2007
    Messages : 476
    Par défaut
    Tu peux utiliser SqlDatasource pour peupler le gridview. La propriété SelectCommand remonte les données en faisant un calcul a la volée. Ensuite le champ sélectionné sera bindé avec leur colonne correspondante.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
                <asp:SqlDataSource ID="SqlDataSource1" runat="server"
                 ConnectionString="<%$ .......... %>"
                  SelectCommand="select Nbre.Table1 , Nbre.Table2, (Nbre.Table2/Nbre.Table1)*100 as Moyenne from Table1
                  inner join Table2 on Tab1.designe=Tab2.designe"
                  </asp:SqlDataSource>
    Gridview bindé:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     <asp:GridView ID="GridView1" runat="server" 
               AutoGenerateColumns="False"
                DataSourceID="SqlDataSource1" 
                <Columns>
                    <asp:BoundField DataField="Nbre.Table1" HeaderText="Nbre.Table1"
                        SortExpression="Nbre.Table1" />
                    <asp:BoundField DataField="Nbre.Table2" HeaderText="Nbre.Table2"  
                        SortExpression="Nbre.Table2"/>
                    <asp:BoundField DataField="Moyenne" HeaderText="Moyenne"
                        SortExpression="Moyenne"/> 
    </asp:GridView>
    En esperant t'avoir aidé

  12. #12
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    367
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 367
    Par défaut
    Merci pour tes réponses, mais j'ai un problème car je suis obligé de construire une requete pour remplir mon gridview (plutôt qu'un AccessDataSource). J'ai écris ce code mais cela beug

    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
    Sub CalcuProg()
            'objet connection
            Using connexion As OleDbConnection = Me.DBConn
                Dim DBCommand As OleDbCommand
                'Objet Dataset
                Dim DSPageData As New DataSet
                'connection a la base de données
                DBCommand = New OleDbCommand("Select CA44.CAsemaine, CA44.CA2009, (CA44.CAsemaine/CA44.CA2009)*100 As ProgCA From CAsemaine, CA2009 Where CAsemaine.Lan= ? and CA2009.Lan=?", connexion)
                'objet DataAdapter
                Dim myOleDbDataAdapter As New OleDbDataAdapter(DBCommand)
                DBCommand.Parameters.AddWithValue("CAsemaine.Lan", Session("Lan"))
                DBCommand.Parameters.AddWithValue("CA2009.Lan", Session("Lan2009"))
                myOleDbDataAdapter.SelectCommand.Parameters("CAsemaine.Lan").Value = Session("Lan")
                myOleDbDataAdapter.Fill(DSPageData, "LePanier")
                GdvTotCA.DataSource = _
                 DSPageData.Tables("LePanier").DefaultView
                GdvTotCA.DataBind()
            End Using
        End Sub
    Et dans mon gridview
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <asp:templatefield headertext="S44">
       <itemtemplate>
       <%#Eval("ProgCA ", "{0:p}")%>
       </itemtemplate>
    </asp:templatefield>
    D'autre part ce résultat correspond à une semaine et il m'en faut 53. Est-il possible de créer dynamiquement ces 52 colonnes, j'ai écris ce code mais cela beug également

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub AjoutColonne()
        Session (“NewCol”)=S45    
    Dim dt As New DataTable()
            dt.Columns.Add(New DataColumn Session (“NewCol”), GetType(String)))
            Dim dr As DataRow = dt.NewRow()
            dr Session (“NewCol”)) = ProgCA
            dt.Rows.Add(dr)
            Me.GdvTotCA.DataSource = dt
            Me.GdvTotCA.DataBind()
    End Sub
    Encore merci pour ton aide

  13. #13
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2007
    Messages
    693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2007
    Messages : 693
    Par défaut
    Bonjour,

    Tu dis que ça beug, quels sont les messages d'erreur ? Sans ça dur de t'aiguiller correctement

  14. #14
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    367
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 367
    Par défaut
    Sur la requete, j'ai le message :
    Aucune valeur donnée pour un ou plusieurs paramètres requis
    Pourtant les tables comportent les données

  15. #15
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2007
    Messages
    693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2007
    Messages : 693
    Par défaut
    Tu as une erreur disant que la valeur de certains paramètres n'a pas été fournie c'est bien ça ?

    Si oui le problème vient de là :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    DBCommand.Parameters.AddWithValue("CAsemaine.Lan", Session("Lan"))
    DBCommand.Parameters.AddWithValue("CA2009.Lan", Session("Lan2009"))

  16. #16
    Membre éprouvé
    Avatar de topolino
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    1 901
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 901
    Par défaut
    Soit tu le fais dans ta requete sql, soit dans dans le rowdatabound de ton gridview.

  17. #17
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    367
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 367
    Par défaut
    Je ne comprends pas dans

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DBCommand.Parameters.AddWithValue("CAsemaine.Lan", Session("Lan"))
    dans la CAsemaine il y a un champs Lan avec des enregistrements=2010 et la Session("Lan")="2010"


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DBCommand.Parameters.AddWithValue("CA2009.Lan", Session("Lan2009"))
    et dans la CA2009 il y a un champs Lan avec des enregistrements=2009 et la Session("Lan2009")="2009"

    Je ne vois pas où est l'erreur

  18. #18
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2007
    Messages
    693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2007
    Messages : 693
    Par défaut
    L'erreur obtenue dit-elle que la valeur de certains paramètres n'a pas été fournie.

    Je dis que si c'est ça c'est que le problème vient très probablement des deux lignes citées.

    MSDN dit :
    Le fournisseur OLE DB .NET ne prend pas en charge les paramètres nommés pour passer des paramètres à une instruction SQL ou à une procédure stockée appelée par un OleDbCommand si CommandType a la valeur Text.Dans ce cas, le point d'interrogation (?) l'espace réservé doit être utilisé.Par exemple :

    SELECT * FROM Customers WHERE CustomerID = ?

    Par conséquent, l'ordre dans lequel les objets OleDbParameter sont ajoutés à OleDbParameterCollection doit correspondre directement à la position de l'espace réservé du point d'interrogation pour le paramètre dans le texte de la commande.
    Il faut donc ajouter les paramètres comme 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
    Public Sub CreateMyOleDbCommand(connection As OleDbConnection, _
       queryString As String, parameters() As OleDbParameter)
     
        Dim command As New OleDbCommand(queryString, connection)
        command.CommandText = _
           "SELECT CustomerID, CompanyName FROM Customers WHERE Country = ? AND City = ?"
        command.Parameters.Add(parameters)
     
        Dim j As Integer
        For j = 0 To command.Parameters.Count - 1
           command.Parameters.Add(parameters(j))
        Next j
     
        Dim message As String = ""
        Dim i As Integer
        For i = 0 To command.Parameters.Count - 1
            message += command.Parameters(i).ToString() + ControlChars.Cr
        Next i
        Console.WriteLine(message)
    End Sub

  19. #19
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    367
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 367
    Par défaut
    Merci pour ta réponse, ce problème est réglé.
    Il me reste celui de l'ajout dynamiquement de colonnes supplémentaires. Je veux ajouter 51 colonnes de S02 à S52.

    identiques à cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <asp:templatefield headertext="S44">
       <itemtemplate>
       <%#Eval("ProgCA ", "{0:p}")%>
       </itemtemplate>
    </asp:templatefield>
    On m'a donné sur le forum un lien où j'ai trouvé ce code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    For Each r As DataRow In d.Rows
    	Dim s As String = DirectCast(r.ItemArray(0), String)
    	Dim maColonne As BoundField
    	maColonne = New BoundField()
    	maColonne.HeaderText = s
    	maColonne.DataField = s
     
    		'mise à jour du select et de l'update
    	GridView1.Columns.Add(maColonne)
    Next
    Mais je ne vois pas ce qu'est le d de d.Rows et comment adapter le code pour obtenir des colonnes comme ci-dessus.

    Peux-tu m'aider ? c'est le dernier problème qu'il mes reste à régler.
    Merci pour ta réponse
    JCM

  20. #20
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2007
    Messages
    693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2007
    Messages : 693
    Par défaut
    Alors tu as une table nommée LePanier dans laquelle tu veux ajouter des colonnes c'est ça ? Enfin ça marche pour n'importe quelle table
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    for i as 2 to 52
      Dim maColumn as new DataColumn(String.Format("S{0}", i.ToString("00"))
      maDataTable.Columns.Add(maColumn)
    next

Discussions similaires

  1. Max calculé sur une partie de cellule
    Par m@tix dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 07/07/2011, 14h09
  2. [XL 2007]Evenement calculate sur une seule cellule
    Par hoaxpunk dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 27/07/2010, 12h29
  3. [XL-2003] Calcul sur une plage de cellules
    Par kokoVBA dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 26/08/2009, 10h35
  4. Lancement macro sur calcul d'une cellule
    Par jalseth dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 11/07/2008, 16h42
  5. capter l'evenement clic sur une cellule d'un string grid
    Par lasconic dans le forum Composants VCL
    Réponses: 3
    Dernier message: 25/06/2003, 10h51

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