Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • World
  • Users
  • Groups
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Code Project
CODE PROJECT For Those Who Code
  • Home
  • Articles
  • FAQ
Community
  1. Home
  2. General Programming
  3. C#
  4. Trying to make a DataGridView field a color if a condition is met.

Trying to make a DataGridView field a color if a condition is met.

Scheduled Pinned Locked Moved C#
help
18 Posts 2 Posters 0 Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • M Mathi Mani

    The error message says it clearly. You are trying to covert a decimal to int. Change your stament like below and try.

    decimal ActualFTE=Convert.ToDecimal(e.Row.Cells[5].Text);
    if (ActualFTE > 1.25)

    N Offline
    N Offline
    Norris Chappell
    wrote on last edited by
    #3

    Duh! Thanks.

    1 Reply Last reply
    0
    • M Mathi Mani

      The error message says it clearly. You are trying to covert a decimal to int. Change your stament like below and try.

      decimal ActualFTE=Convert.ToDecimal(e.Row.Cells[5].Text);
      if (ActualFTE > 1.25)

      N Offline
      N Offline
      Norris Chappell
      wrote on last edited by
      #4

      Still getting the same error. :(

      M 1 Reply Last reply
      0
      • N Norris Chappell

        Still getting the same error. :(

        M Offline
        M Offline
        Mathi Mani
        wrote on last edited by
        #5

        Can you post what value is coming in

        e.Row.Cells[5].Text

        It will give a better idea on what we are dealing with.

        N 2 Replies Last reply
        0
        • M Mathi Mani

          Can you post what value is coming in

          e.Row.Cells[5].Text

          It will give a better idea on what we are dealing with.

          N Offline
          N Offline
          Norris Chappell
          wrote on last edited by
          #6

          the count is 9.

          1 Reply Last reply
          0
          • M Mathi Mani

            Can you post what value is coming in

            e.Row.Cells[5].Text

            It will give a better idea on what we are dealing with.

            N Offline
            N Offline
            Norris Chappell
            wrote on last edited by
            #7

            sorry I meant 0.9500

            M 1 Reply Last reply
            0
            • N Norris Chappell

              sorry I meant 0.9500

              M Offline
              M Offline
              Mathi Mani
              wrote on last edited by
              #8

              decimal ActualFTE=Convert.ToDecimal(e.Row.Cells[5].Text);
              if (ActualFTE > 1.25)

              In the above code check whether e.Row.Cells[5].Text returns data that can be converted to decimal. Or add ToString() at the end and see if it helps.

              decimal ActualFTE=Convert.ToDecimal(e.Row.Cells[5].Text.ToString());

              N 1 Reply Last reply
              0
              • M Mathi Mani

                decimal ActualFTE=Convert.ToDecimal(e.Row.Cells[5].Text);
                if (ActualFTE > 1.25)

                In the above code check whether e.Row.Cells[5].Text returns data that can be converted to decimal. Or add ToString() at the end and see if it helps.

                decimal ActualFTE=Convert.ToDecimal(e.Row.Cells[5].Text.ToString());

                N Offline
                N Offline
                Norris Chappell
                wrote on last edited by
                #9

                Same error: Input string was not in a correct format.

                M 1 Reply Last reply
                0
                • N Norris Chappell

                  Same error: Input string was not in a correct format.

                  M Offline
                  M Offline
                  Mathi Mani
                  wrote on last edited by
                  #10

                  Just to make sure everything is fine, try hardcoding the value and see if you still get the error.

                  decimal ActualFTE=Convert.ToDecimal("0.9500");

                  If this works without exception, then you can be sure, the problem is with the expression e.Row.Cells[5].Text. This expression you use should return some string (like your value 0.9500) that can be converted to decimal for the conversion to work without exception.

                  N 1 Reply Last reply
                  0
                  • M Mathi Mani

                    Just to make sure everything is fine, try hardcoding the value and see if you still get the error.

                    decimal ActualFTE=Convert.ToDecimal("0.9500");

                    If this works without exception, then you can be sure, the problem is with the expression e.Row.Cells[5].Text. This expression you use should return some string (like your value 0.9500) that can be converted to decimal for the conversion to work without exception.

                    N Offline
                    N Offline
                    Norris Chappell
                    wrote on last edited by
                    #11

                    okay it didn't error this time but nothing changed.

                    M 1 Reply Last reply
                    0
                    • N Norris Chappell

                      okay it didn't error this time but nothing changed.

                      M Offline
                      M Offline
                      Mathi Mani
                      wrote on last edited by
                      #12

                      May be the value ActualFTE is not greater than 1.25, as per your condition.

                         if (ActualFTE > 1.25)
                         {
                            e.Row.BackColor = Color.Red;
                          }
                      

                      So the color will not be changed.

                      N 2 Replies Last reply
                      0
                      • M Mathi Mani

                        May be the value ActualFTE is not greater than 1.25, as per your condition.

                           if (ActualFTE > 1.25)
                           {
                              e.Row.BackColor = Color.Red;
                            }
                        

                        So the color will not be changed.

                        N Offline
                        N Offline
                        Norris Chappell
                        wrote on last edited by
                        #13

                        That is true for most of the 251 rows. I only see a couple that are over 1.25. So I should take out that code?

                        1 Reply Last reply
                        0
                        • M Mathi Mani

                          May be the value ActualFTE is not greater than 1.25, as per your condition.

                             if (ActualFTE > 1.25)
                             {
                                e.Row.BackColor = Color.Red;
                              }
                          

                          So the color will not be changed.

                          N Offline
                          N Offline
                          Norris Chappell
                          wrote on last edited by
                          #14

                          Do you think I should post all of my code to see if I have something missing?

                          M 1 Reply Last reply
                          0
                          • N Norris Chappell

                            Do you think I should post all of my code to see if I have something missing?

                            M Offline
                            M Offline
                            Mathi Mani
                            wrote on last edited by
                            #15

                            When you want the row to be colored? Change the if condition based on that. It should work.

                            N 1 Reply Last reply
                            0
                            • M Mathi Mani

                              When you want the row to be colored? Change the if condition based on that. It should work.

                              N Offline
                              N Offline
                              Norris Chappell
                              wrote on last edited by
                              #16

                              Not the whole row only that field. ActualFTE.

                              using System;
                              using System.Configuration;
                              using System.Data;
                              using System.Data.SqlClient;
                              using System.Web.UI;
                              using System.Drawing;
                              using System.Web.UI.WebControls;
                              using System.Web.UI.WebControls.WebParts;

                              namespace StaffingWebParts.CatwComment
                              {
                              public partial class CatwCommentUserControl : UserControl
                              {
                              SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["SQLStaffingConn"].ConnectionString);
                              SqlCommand cmd = new SqlCommand();

                                  protected void Page\_Load(object sender, EventArgs e)
                                  {
                                      lblMsg.Text = "";
                                      if (!Page.IsPostBack)
                                      {
                                          BindSubjectData();
                                      }
                                  }
                                  protected void highlightrow(object sender, GridViewRowEventArgs e)
                                  {
                                     if (e.Row.RowType == DataControlRowType.DataRow)
                                     {
                                       decimal ActualFTE = Convert.ToDecimal(e.Row.Cells\[5\].Text.ToString());
                                         
                                       if (ActualFTE > 1.2500M)
                                         {
                                            e.Row.BackColor = Color.Red;
                                          }
                                      }
                                  }
                                  //call to bind gridview
                                  protected void BindSubjectData()
                                  {
                                      using (SqlConnection sqlCon = new SqlConnection(ConfigurationManager.ConnectionStrings\["SQLStaffingConn"\].ConnectionString))
                                      {
                                          using (SqlCommand cmd = new SqlCommand())
                                          {
                                              cmd.CommandText = ("select a.id, b.StaffTrackingID, a.ResourceName, b. EstimateHours, EstimateFTE, b.ActualHours, b.ActualFTE,b.Comment, b.CommentBy, b.Period  from  StaffTracking a, StaffTrackingFTEData b where a.id = b.StaffTrackingid  order by ResourceName");
                                              cmd.Connection = sqlCon;
                                              sqlCon.Open();
                                              SqlDataAdapter da = new SqlDataAdapter(cmd);
                                              DataTable dt = new DataTable();
                                                             
                                              da.Fill(dt);
                                              if (dt.Rows.Count > 0)
                                              {
                                                  gvCATW.DataSource = dt;
                                                  gvCATW.DataBind();
                                              }
                                              else
                                              {
                                                  DataRow dr = dt.NewRow();
                                                  dt.Rows.Add(dr);
                                                  gvCATW.DataSource = dt;
                                                  gvCATW.DataBind();
                                                  gvCATW.Rows\[0\].Visible = false;
                              
                              M 1 Reply Last reply
                              0
                              • N Norris Chappell

                                Not the whole row only that field. ActualFTE.

                                using System;
                                using System.Configuration;
                                using System.Data;
                                using System.Data.SqlClient;
                                using System.Web.UI;
                                using System.Drawing;
                                using System.Web.UI.WebControls;
                                using System.Web.UI.WebControls.WebParts;

                                namespace StaffingWebParts.CatwComment
                                {
                                public partial class CatwCommentUserControl : UserControl
                                {
                                SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["SQLStaffingConn"].ConnectionString);
                                SqlCommand cmd = new SqlCommand();

                                    protected void Page\_Load(object sender, EventArgs e)
                                    {
                                        lblMsg.Text = "";
                                        if (!Page.IsPostBack)
                                        {
                                            BindSubjectData();
                                        }
                                    }
                                    protected void highlightrow(object sender, GridViewRowEventArgs e)
                                    {
                                       if (e.Row.RowType == DataControlRowType.DataRow)
                                       {
                                         decimal ActualFTE = Convert.ToDecimal(e.Row.Cells\[5\].Text.ToString());
                                           
                                         if (ActualFTE > 1.2500M)
                                           {
                                              e.Row.BackColor = Color.Red;
                                            }
                                        }
                                    }
                                    //call to bind gridview
                                    protected void BindSubjectData()
                                    {
                                        using (SqlConnection sqlCon = new SqlConnection(ConfigurationManager.ConnectionStrings\["SQLStaffingConn"\].ConnectionString))
                                        {
                                            using (SqlCommand cmd = new SqlCommand())
                                            {
                                                cmd.CommandText = ("select a.id, b.StaffTrackingID, a.ResourceName, b. EstimateHours, EstimateFTE, b.ActualHours, b.ActualFTE,b.Comment, b.CommentBy, b.Period  from  StaffTracking a, StaffTrackingFTEData b where a.id = b.StaffTrackingid  order by ResourceName");
                                                cmd.Connection = sqlCon;
                                                sqlCon.Open();
                                                SqlDataAdapter da = new SqlDataAdapter(cmd);
                                                DataTable dt = new DataTable();
                                                               
                                                da.Fill(dt);
                                                if (dt.Rows.Count > 0)
                                                {
                                                    gvCATW.DataSource = dt;
                                                    gvCATW.DataBind();
                                                }
                                                else
                                                {
                                                    DataRow dr = dt.NewRow();
                                                    dt.Rows.Add(dr);
                                                    gvCATW.DataSource = dt;
                                                    gvCATW.DataBind();
                                                    gvCATW.Rows\[0\].Visible = false;
                                
                                M Offline
                                M Offline
                                Mathi Mani
                                wrote on last edited by
                                #17

                                Refere this question for changing the color of a grid row based on some condition. The code is in Vb.Net but you can get the idea. How Can I Change A Rows Backcolour Based On The Value In The First Cell Of The Same Row[^]

                                N 1 Reply Last reply
                                0
                                • M Mathi Mani

                                  Refere this question for changing the color of a grid row based on some condition. The code is in Vb.Net but you can get the idea. How Can I Change A Rows Backcolour Based On The Value In The First Cell Of The Same Row[^]

                                  N Offline
                                  N Offline
                                  Norris Chappell
                                  wrote on last edited by
                                  #18

                                  Mathi, I was able to get it to work. Thank you for your help and patience. You and others have help me to complete this project.

                                  protected void gvCATW_RowDataBound(object sender, GridViewRowEventArgs e)

                                  {
                                  if (e.Row.RowType == DataControlRowType.DataRow)
                                  {

                                  // To check condition on integer value
                                  if (Convert.ToDecimal(DataBinder.Eval(e.Row.DataItem, "ActualFTE")) > 1.25M)
                                  {
                                    e.Row.BackColor = System.Drawing.Color.Red;
                                  }
                                  

                                  }

                                  1 Reply Last reply
                                  0
                                  Reply
                                  • Reply as topic
                                  Log in to reply
                                  • Oldest to Newest
                                  • Newest to Oldest
                                  • Most Votes


                                  • Login

                                  • Don't have an account? Register

                                  • Login or register to search.
                                  • First post
                                    Last post
                                  0
                                  • Categories
                                  • Recent
                                  • Tags
                                  • Popular
                                  • World
                                  • Users
                                  • Groups