当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 点击DataGrid的列标头在DataGrid最后一行显示该列的和

ASP.NET
使用C# 开发掩码输入文本框
点击DataGrid的列标头在DataGrid最后一行显示该列的和
ASP.NET之Web打印-终极解决篇
SQL Server 2000 Reporting Services: 怎样根据用户的语言偏好显示本地化的信息
利用底层键盘钩子拦载任意按键(回调版)
如何禁止调整自定义控件的尺寸?
用VB6.0编写磁盘格式化程序
Aspx中导Excel
ASP.NET组件设计Step by Step(3)
下面真正开始讲事件的内容
如何有效的使用C#读取文件
如何在C#中加载自己编写的动态链接库(DLL)
Managed DirectX 相关(DirectX.Capture Class Library && DirectShow.NET)
XQuery Reference-from w3schools.com
[译]Visual Basic 2005在语言上的增强(十三)显式的数组范围及小结
lucene的首次应用
[VBA]在后台删除工作表后出现的怪问题
VB.NET 数据库查询 [SQL字符串的生成]
JavaScript调用服务器事件
在Window2003上执行System.Diagnostics.Process.GetProcessesByName等方法失败的原因

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 47 ::
收藏到网摘: n/a


单击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+"\r\n"+fe.Source);
}
myTable.Rows.Add(dr);
Sumed=true;
}
}
}