点击DataGrid的列标头在DataGrid最后一行显示该列的和

用户无法修改77

用户无法修改77

2016-01-29 13:00

点击DataGrid的列标头在DataGrid最后一行显示该列的和,点击DataGrid的列标头在DataGrid最后一行显示该列的和

单击DATAGRID 的某一列时,在DATAGRID的最后增加一行,把整列的和显示在增加的这一行里。
如果想简单的方法的话请参见:DataColumn.Expression 属性 [C#]:获取或设置表达式,用于筛选行、计算列中的值或创建聚合列。
笨方法如下:
bool Sumed=false;//指示是否在最后一行显示了该列的和
private void dataGrid1_MouseDown(object sender, System.Windows.Forms.MouseEventArgs e)
{
DataGrid.HitTestInfo hit=this.dataGrid1.HitTest(e.X,e.Y);
if(hit.Column!=-1)
{
try
{
this.dataGrid1.GetCellBounds(hit.Row,hit.Column);//取该单元格的Rectangle,如果出错说明单击了列标头
}
catch(System.IndexOutOfRangeException oir)
{//单击了列标头之后,功能代码->求和,添加到最后一列
int Sum=0;//某列总和
int iRow;
DataTable myTable;
myTable = (DataTable) ((DataSet)this.dataGrid1.DataSource).Tables[0];
if(Sumed)//如果datagrid已经添加了该列的和则在下次计算时应移除
{
DataRow drSum=myTable.Rows[myTable.Rows.Count-1];
drSum.Delete();
}
for(iRow = 0;iRow < myTable.Rows.Count ;iRow++)
{
Sum+=System.Convert.ToInt32(this.dataGrid1[iRow,hit.Column].ToString());//计算该列总和

}
//以下为添加到该列的最后一行代码
System.Data.DataRow dr=myTable.NewRow();
try
{
for(int k=0;k {
if(k==hit.Column)
{
dr[k]=Sum.ToString();//该列的和添加到列尾
}
else//其他列
{
//MessageBox.Show();
switch(dr[k].GetType().ToString())
{
case "System.Int32":
dr[k]=0;
break;
case "System.String":
dr[k]="总和";
break;
}
}
}
}
catch(System.FormatException fe)
{
MessageBox.Show(fe.Message+"rn"+fe.Source);
}
myTable.Rows.Add(dr);
Sumed=true;
}
}
}
展开更多 50%)
分享

猜你喜欢

点击DataGrid的列标头在DataGrid最后一行显示该列的和

电脑网络
点击DataGrid的列标头在DataGrid最后一行显示该列的和

Excel快速移动到最后一行一列

电脑入门
Excel快速移动到最后一行一列

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

给datagrid的按钮列添加css

Web开发
给datagrid的按钮列添加css

在DataGrid中添加Radio单选按钮列

电脑网络
在DataGrid中添加Radio单选按钮列

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

如何在DataGrid控件中隐藏列

ASP
如何在DataGrid控件中隐藏列

如何在 dataGrid 上的第一列加上 CheckBox

ASP
如何在 dataGrid 上的第一列加上 CheckBox

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

《部落战争》黑水资源获得攻略

《部落战争》黑水资源获得攻略

在Window2003上执行System.Diagnostics.Process.GetProcessesByName等方法失败的原因

在Window2003上执行System.Diagnostics.Process.GetProcessesByName等方法失败的原因
下拉加载更多内容 ↓