怎么遍历得到gridview某一列的值

怎么遍历得到gridview某一列的值.数据库中有一列是时间列,我想用一个变量保存当前时间,如果gridview中有一列的值和当前时间相等的话,那一行的背景颜色就变红色!

以gridview控件名称为gv来说,
this.gv.Rows[0].Cells[0].Value,不能直接取出某列的全部值,因为表格控件是先按行后按列使用的。因此可以写一个循环(for或者foreach)遍历所有行gv.Rows,在当前行中获取某列的数据。如前面的代码。如果单元格中加了其他控件,还要转换类型。
温馨提示:内容为网友见解,仅供参考
第1个回答  2009-07-23
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这种类型了。
第2个回答  推荐于2017-09-11
你说的和当前时间相等是指年月日相等吧,没有时分秒吧
我给一个只判年月日相等的例子
如果你需要时分秒也相等的话,简单的改一下就可以了

前台很简单

<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");
}
}
}

我试过了,没问题的!本回答被提问者采纳
第3个回答  2009-07-19
DateTime data = DataTime.Current;
foreach(DataRow dr in gridview.Rows)
{
if(Convert.ToDateTime(dr['columnname']).Eques(date))
{
date = Convert.ToDateTime(dr['columnname']);
break
}
}

怎么遍历得到gridview某一列的值
以gridview控件名称为gv来说,this.gv.Rows[0].Cells[0].Value,不能直接取出某列的全部值,因为表格控件是先按行后按列使用的。因此可以写一个循环(for或者foreach)遍历所有行gv.Rows,在当前行中获取某列的数据。如前面的代码。如果单元格中加了其他控件,还要转换类型。

C#中循环读取GridView控件中值的问题
取单元格显示文本不是Value哦,应该是Text属性。double money = 0;foreach (DataGridViewRow Row in dvCost.Rows){ money += Convert.ToDouble(Row.Cells[3].Text);} lblMoney.Text = money.ToString();

C#点击datagridview某行就将某行显示到另一个datagridview怎么设置?
点击按钮后,遍历数据,将其放入一个datatable中。然后,将此datatable绑定到另一个datagridview即可。这样,该datatable将保持状态,每次点击都会累加到其中。另一种方法是在第一个gridview中添加复选框。选择要添加到另一个gridview的行后,点击按钮遍历gridview,将被复选框选中的行的数据一起添加到data...

如何获取datagridview行号和列号?
解决方法一:遍历datagridview所有行和列 匹配你输入的值 dataGridView1.Rows[索引]获取行 dataGridView1.Rows[索引].Cells[索引]获取该行的某一项,然后记录下rows的索引 和cells的索引就是你要的行号和列号 解决方法二:为该datagridview添加CellClick这个事件(点击项触发的事件)private void dataGridView...

extjs如何获取Grid中某一行某一列的值
Ext.grid.GridView.getCell( Number row, Number col ):取得指定单元格对应的td元素 例如: var sStr=Ext.grid.GridView.getCell(0,0); 再给你一些extjs常用的方法、属性 1、Ext.grid.GridPanel 主要配置项: store:表格的数据集 columns:表格列模式的配置数组,可自动创建ColumnModel列模式 autoExpandColumn...

C#如何获取datagridview最后一行第一列数据的值
var dgv = this.dataGridView1; int max = (int)dgv.Rows[dgv.RowCount - 1].Cells[0].Value;

dev Express 遍历gridView的每一列,看清楚是列,不是行
for (int i = 0; i < gridView.Columns.Count ; i++){ if (gridView.Columns[i].Visible){ gridView.Columns[i].VisibleIndex = 0;} }

Winform 中,批量删除数据时,需要遍历checkbox列是否被选中,如何获取被...
选中一个,那么id=1 选中两个,那么id=1 and id=2 选中几个,那就有多少个索引。当前的话,就直接获取。多行的话,就循环遍历下咯\/ 参考个代码:private string GetSelectedItemID(string controlID){ String selectedID;selectedID = "";\/\/遍历DataGrid获得checked的ID foreach (GridViewRow row...

asp.net中怎么读取gridview单元格的值
GridView1.Rows[0].Cells[0].Text Rows[0] Cells[0],0是指的下标。看你是在那个事件下面读取。如果是Gridview 自己的事件,行的下标可以为e.index 取得当前 行数值 如果是其他的事件,那你就得遍历了。希望能帮到你。

C#怎么取出GridView中的每一行数据,然后弄成字符串插入到数据库中...
data.Rows.Count; k++)\/\/循环每一行 { string str = "";for (int i = 0; i < data.Rows[i].Cells.Count; i++)\/\/循环每一列 { str += data.Rows[k].Cells[i].ToString() + " ";\/\/把每列中的数据添加到str中 } \/\/执行sql语句 把str插入到指定数据库表中 \/\/...} ...

相似回答