关于C# dataGridView符合条件的行变颜色的问题
for(inti=0;i<dataGridView2.Rows.Count;i++){for(intj=0;j<dataGridView1.Rows.Count;j++)...
for (int i = 0; i < dataGridView2.Rows.Count; i++)
{
for (int j = 0; j < dataGridView1.Rows.Count; j++)
{
if (dataGridView2.Rows[i].Cells[1].Value == dataGridView1.Rows[j].Cells[1].Value)
{
if (dataGridView2.Rows[i].Cells[2].Value == dataGridView1.Rows[j].Cells[2].Value)
{
//两列值相同变红颜色
dataGridView2.Rows[i].Cells[1].Style.BackColor = Color.Red;
dataGridView2.Rows[i].Cells[2].Style.BackColor = Color.Red;
}
else if (dataGridView2.Rows[i].Cells[2].Value != dataGridView1.Rows[j].Cells[2].Value)
{
//一列值相同变黄颜色
dataGridView2.Rows[i].Cells[1].Style.BackColor = Color.Yellow;
}
}
}
}
我写了如上一段代码 想把 dataGridView2里跟 dataGridView1重复的行变个颜色,但是实现不了,求明眼人给看看哪有问题。 展开
{
for (int j = 0; j < dataGridView1.Rows.Count; j++)
{
if (dataGridView2.Rows[i].Cells[1].Value == dataGridView1.Rows[j].Cells[1].Value)
{
if (dataGridView2.Rows[i].Cells[2].Value == dataGridView1.Rows[j].Cells[2].Value)
{
//两列值相同变红颜色
dataGridView2.Rows[i].Cells[1].Style.BackColor = Color.Red;
dataGridView2.Rows[i].Cells[2].Style.BackColor = Color.Red;
}
else if (dataGridView2.Rows[i].Cells[2].Value != dataGridView1.Rows[j].Cells[2].Value)
{
//一列值相同变黄颜色
dataGridView2.Rows[i].Cells[1].Style.BackColor = Color.Yellow;
}
}
}
}
我写了如上一段代码 想把 dataGridView2里跟 dataGridView1重复的行变个颜色,但是实现不了,求明眼人给看看哪有问题。 展开
2个回答
展开全部
你这段代码写的是不是不严谨啊???或者说,你的数据是不是第一列的数据是唯一的啊??
假如有这种情况的话,你的程序肯定达不到效果:
暂定dataGridView1=表1,dataGridView2=表2
如果表1与表2的第一行,完全一样:j=0时,表2第一行应该为红色;
如果表2的第一行第一列与表1的第二行第一列相同,第二列不同,则j=1时,表2第一行变成黄色。
......................
楼主,你再检查下你的数据是不是有这种情况。
假如有这种情况的话,你的程序肯定达不到效果:
暂定dataGridView1=表1,dataGridView2=表2
如果表1与表2的第一行,完全一样:j=0时,表2第一行应该为红色;
如果表2的第一行第一列与表1的第二行第一列相同,第二列不同,则j=1时,表2第一行变成黄色。
......................
楼主,你再检查下你的数据是不是有这种情况。
追问
是没仔细写,主要看能不能变色,现在数据非常简单,不存在你说的那种情况,可就是不变色啊
追答
this.dataGridView1.Rows[0].Cells[1].Style.BackColor = Color.Red; 这个是完全可以变色的!!只可惜我这网速很差,上传不了图片,要不给你看看!!!
建议你还是先调试代码吧,因为你这样复制的形式来改变颜色是可以的,至于为什么没有效果,我估计是你的循环判断过程中出了BUG
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询