怎么遍历得到gridview某一列的值
怎么遍历得到gridview某一列的值.数据库中有一列是时间列,我想用一个变量保存当前时间,如果gridview中有一列的值和当前时间相等的话,那一行的背景颜色就变红色!...
怎么遍历得到gridview某一列的值.数据库中有一列是时间列,我想用一个变量保存当前时间,如果gridview中有一列的值和当前时间相等的话,那一行的背景颜色就变红色!
展开
4个回答
展开全部
for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
{
int n=//想要的那一列的号码,是号码,INT型(比如4)
string abc= GridView1.Rows[i].Cells[n].Tostring();
if (abc == System.DataTime.Now)
{
GridView1.Rows[i].Cells[n].BackColor = System.Drawing.Color.Red;
}
}
看到楼下考虑到时分秒的问题,确实是我疏忽了。时分秒有个简单的办法,就是Tostring("d")这样就直接转换YYYY-MM-DD这种类型了。
{
int n=//想要的那一列的号码,是号码,INT型(比如4)
string abc= GridView1.Rows[i].Cells[n].Tostring();
if (abc == System.DataTime.Now)
{
GridView1.Rows[i].Cells[n].BackColor = System.Drawing.Color.Red;
}
}
看到楼下考虑到时分秒的问题,确实是我疏忽了。时分秒有个简单的办法,就是Tostring("d")这样就直接转换YYYY-MM-DD这种类型了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你说的和当前时间相等是指年月日相等吧,没有时分秒吧
我给一个只判年月日相等的例子
如果你需要时分秒也相等的话,简单的改一下就可以了
前台很简单
<asp:GridView ID="GridView1" runat="server" OnRowDataBound="GridView1_RowDataBound">
</asp:GridView>
后台也不很简单
protected void Page_Load(object sender, EventArgs e)
{
DataTable dt = new DataTable();
dt.Columns.Add("DATE", typeof(DateTime));
dt.Columns.Add("OTHERS",typeof(string));
DataRow dr = dt.NewRow();
dr["DATE"] = DateTime.Now.AddDays(-1);
dr["OTHERS"] = "aaa";
dt.Rows.Add(dr);
DataRow dr2 = dt.NewRow();
dr2["DATE"] = DateTime.Now;
dr2["OTHERS"] = "bbb";
dt.Rows.Add(dr2);
this.GridView1.DataSource = dt;
this.GridView1.DataBind();
}
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
if (((System.DateTime)(((System.Data.DataRowView)(e.Row.DataItem)).Row.ItemArray[0])).ToShortDateString().Equals(DateTime.Now.ToShortDateString()))
{
e.Row.Attributes.Add("style", "background-color:Red");
}
}
}
我试过了,没问题的!
我给一个只判年月日相等的例子
如果你需要时分秒也相等的话,简单的改一下就可以了
前台很简单
<asp:GridView ID="GridView1" runat="server" OnRowDataBound="GridView1_RowDataBound">
</asp:GridView>
后台也不很简单
protected void Page_Load(object sender, EventArgs e)
{
DataTable dt = new DataTable();
dt.Columns.Add("DATE", typeof(DateTime));
dt.Columns.Add("OTHERS",typeof(string));
DataRow dr = dt.NewRow();
dr["DATE"] = DateTime.Now.AddDays(-1);
dr["OTHERS"] = "aaa";
dt.Rows.Add(dr);
DataRow dr2 = dt.NewRow();
dr2["DATE"] = DateTime.Now;
dr2["OTHERS"] = "bbb";
dt.Rows.Add(dr2);
this.GridView1.DataSource = dt;
this.GridView1.DataBind();
}
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
if (((System.DateTime)(((System.Data.DataRowView)(e.Row.DataItem)).Row.ItemArray[0])).ToShortDateString().Equals(DateTime.Now.ToShortDateString()))
{
e.Row.Attributes.Add("style", "background-color:Red");
}
}
}
我试过了,没问题的!
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
DateTime data = DataTime.Current;
foreach(DataRow dr in gridview.Rows)
{
if(Convert.ToDateTime(dr['columnname']).Eques(date))
{
date = Convert.ToDateTime(dr['columnname']);
break
}
}
foreach(DataRow dr in gridview.Rows)
{
if(Convert.ToDateTime(dr['columnname']).Eques(date))
{
date = Convert.ToDateTime(dr['columnname']);
break
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询