GridView中数据的汇总方法
首先,在页面添加事件<ASP:GridView OnRowDataBound="Gridview1_DataBound">
其次,后台具体方法:
public void Gridview1_DataBound(object sender, System.Web.UI.WebControls.GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
if (((Label)e.Row.FindControl("IF_VALID")).Text.ToString().Trim() == "作废")
{
e.Row.BackColor = System.Drawing.Color.LightGray;
}
if (e.Row.RowType == DataControlRowType.DataRow)
{
string current01 = String.Format("{0:0.00}", DataBinder.Eval(e.Row.DataItem, "COST_NAME"));
switch (current01) { case "": total01 += 0; break; default: total01 += Convert.ToDouble(current01); break; }
}
if (e.Row.RowType == DataControlRowType.Footer)
{
e.Row.Cells[8].Text = "运输成本小计:";
e.Row.Cells[9].Text = string.Format("{0:#,##0.00}", total01);
Response.Write("<script language ='javascript'> window.parent.document.getElementById('yscb').value=" + total01 + ";</script> ");
Response.Write("<script language ='javascript'> window.parent.cal_ct_profit();</script> ");
}
string ywcb;
string yscb;
string kpfy;
double profit = 0;
ywcb = DataBinder.Eval(e.Row.DataItem, "COST_NAME").ToString();
yscb = DataBinder.Eval(e.Row.DataItem, "COST_YUNSHU").ToString();
kpfy = DataBinder.Eval(e.Row.DataItem, "Exhibit_amount").ToString();
switch (ywcb) { case "": profit -= 0; break; default: profit -= double.Parse(ywcb); break; }
switch (yscb) { case "": profit -= 0; break; default: profit -= double.Parse(yscb); break; }
switch (kpfy) { case "": profit += 0; break; default: profit += double.Parse(kpfy); break; }
e.Row.Cells[profit_column].Text = String.Format("{0:0.00}", profit);
if (profit < 0)
{
e.Row.Cells[profit_column].ForeColor = System.Drawing.Color.Red;
}
//string current01 = String.Format("{0:0}", DataBinder.Eval(e.Row.DataItem, "CARTON20_COUNT"));
//string current02 = String.Format("{0:0}", DataBinder.Eval(e.Row.DataItem, "CARTON40_COUNT"));
//string current03 = String.Format("{0:0}", DataBinder.Eval(e.Row.DataItem, "CARTON45_COUNT"));
string current04 = String.Format("{0:0.00}", DataBinder.Eval(e.Row.DataItem, "COST_NAME"));
string current05 = String.Format("{0:0.00}", DataBinder.Eval(e.Row.DataItem, "COST_YUNSHU"));
string current06 = String.Format("{0:0.00}", DataBinder.Eval(e.Row.DataItem, "Exhibit_amount"));
//switch (current01) { case "": total01 += 0; break; default: total01 += int.Parse(current01); break; }
//switch (current02) { case "": total02 += 0; break; default: total02 += int.Parse(current02); break; }
//switch (current03) { case "": total03 += 0; break; default: total03 += int.Parse(current03); break; }
switch (current04) { case "": total04 += 0; break; default: total04 += double.Parse(current04); break; }
switch (current05) { case "": total05 += 0; break; default: total05 += double.Parse(current05); break; }
switch (current06) { case "": total06 += 0; break; default: total06 += double.Parse(current06); break; }
//total07 += profit;
}
total00 = GridView1.Rows.Count;
ShowPageStatus(string.Format("{0:#,##0}", total00), total04, total05, total06);
}
private void ShowPageStatus(string nRecords, double ywcb, double yscb, double kpfy)
{
ShowTTL.Text = "总计<b><FONT color= #9C0001> " + nRecords + " </FONT></b>箱, 出车费<b><FONT color= #9C0001> " + ywcb + " </FONT></b>元, 运输费<b><FONT color= #9C0001> " + yscb + " </FONT></b>元, 亏盈金额<b><FONT color= #9C0001> " + kpfy + " </FONT></b>元";
}
private void ShowCTTTL(double T20, double T40, double T45)
{
ShowCount.Text = "20尺 <b><FONT color= #9C0001> " + T20 + " </FONT></b>, 40尺 <b><FONT color= #9C0001> " + T40 + " </FONT></b>, 45尺 <b><FONT color= #9C0001> " + T45 + " </FONT></b>。";
}
GridView中数据的汇总方法的更多相关文章
- GridView中数据行的操作
一个是直接动态绑定gridview 用3楼的办法就可以了 int j=1;//j的数值表示你要取的那一列的索引,要取第二列,j就设为1for (int i = 0; i < this.GridV ...
- Repeater 和 GridView 中数据格式化
GridView中显示两位小数: <asp:BoundField DataField="investmoney" DataFormatString="{0:f2}& ...
- 【转】GridView中页脚汇总显示
来源:http://blog.csdn.net/atian15/article/details/3495514 有时候需要在GridView的页脚中汇总显示一些信息,常见的方法有两种: 1.在SQL中 ...
- MongoDB 中数据的替换方法实现 --类Replace()函数功能
关键字: MongoDB,Replace,forEach 近日接到一个开发需求,因业务调整,需要DBA协助,将MongoDB数据库中某集合的进行替换.例如我们需要将集合A中B字段中,有关<美好& ...
- PyQt学习随笔:Model/View设计中支持视图中数据修改的方法及步骤
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 要支持视图中的数据可以修改,需要两个步骤: 1. 在视图中设置editTriggers属性支持在视图 ...
- JS中数据类型转换
JS中数据类型转换汇总 JS中的数据类型分为 [基本数据类型] 数字 number 字符串 string 布尔 boolean 空 null 未定义 undefined [引用数据类型] 对象 obj ...
- 通过删除hbase表中的region来达到删除表中数据
公司最近在搞一个hbase删除数据,由于在建表的时候是通过region来对每日的数据进行存储的,所以要求在删除的时候直接通过删除region的来删除数据(最好的方案是只删除region中的数据,不把r ...
- .net中从GridView中导出数据到excel(详细)
1,创建数据源 找到要导出的GridView中的数据. 2,重写VerifyRenderingInServerForm方法. public override void VerifyRenderingI ...
- 一个在ASP.NET中利用服务器控件GridView实现数据增删改查的例子
备注:这是我辅导的一个项目开发组的一个例子,用文章的方式分享出来,给更多的朋友参考.其实我们这几年的项目中,都不怎么使用服务器控件的形式了,而是更多的采用MVC这种开发模式.但是,如果项目的历史背景是 ...
随机推荐
- 集成一体化的移动POS开单扫描解决方案--"移动开单掌上POS"。它集后台管理软件
针对商贸企业的批发.零售管理设计的软硬件集成一体化的移动POS开单扫描解决方案--"移动开单掌上POS".它集后台管理软件.商品价格.库存等信息查询,店铺.展销会开单,移动捡货配送 ...
- LeetCode 104. Maximum Depth of Binary Tree
Problem: Given a binary tree, find its maximum depth. The maximum depth is the number of nodes along ...
- 北京电子科技学院(BESTI)实验报告4
北京电子科技学院(BESTI)实验报告4 课程: 信息安全系统设计基础 班级:1452.1453 姓名:(按贡献大小排名)周恩德 .郑凯杰 学号:(按贡献大小排名)20145217 .201453 指 ...
- Manthan, Codefest 16(B--A Trivial Problem)
B. A Trivial Problem time limit per test 2 seconds memory limit per test 256 megabytes input standar ...
- 深入理解JavaScript运行机制
深入理解JavaScript运行机制 前言 本文是写作在给团队新人培训之际,所以其实本文的受众是对JavaScript的运行机制不了解或了解起来有困难的小伙伴.也就是说,其实真正的原理和本文阐述的并不 ...
- UVALive-4839 HDU-3686 Traffic Real Time Query System 题解
题目大意: 有一张无向连通图,问从一条边走到另一条边必定要经过的点有几个. 思路: 先用tarjan将双连通分量都并起来,剩下的再将割点独立出来,建成一棵树,之后记录每个点到根有几个割点,再用RMQ求 ...
- [JSOI2008]完美的对称 题解
题目大意: 首先我们给定一点A以及对称中心S,点A'是点A以S为对称中心形成的像点,即点S是线段AA'的对称中心. 点阵组(X)以S为中心的像点是由每个点的像点组成的点阵组.X是用来产生对称中心S的, ...
- ASP.NET中获取Repeater模板列中LinkButton按钮事件中获取ID等
前台页面中: <asp:Repeater ID="repComment" runat="server"> <ItemTe ...
- 两种让tableview返回顶部的方法
1. [self.tableView selectRowAtIndexPath:[NSIndexPath indexPathForRow:_currentRow inSection:0] animat ...
- asp.net mvc3登录验证
1,在web.config中 <system.web>节点下面增加: <authentication mode="Forms"> <forms na ...