Hi akhter,
Check this sample. now take its reference and correct your code.
HTML
<asp:GridView ID="gvStock" runat="server" OnDataBound="gvStock_DataBound" OnRowCreated="OnRowCreated">
</asp:GridView>
Namespaces
C#
using System.Data;
using System.Drawing;
VB.Net
Imports System.Data
Imports System.Drawing
Code
C#
protected void Page_Load(object sender, EventArgs e)
{
if (!this.IsPostBack)
{
DataTable dt = new DataTable();
dt.Columns.AddRange(new DataColumn[] {
new DataColumn("Category"),
new DataColumn("Name"),
new DataColumn("Balance"),
new DataColumn("W_Balance"),
});
dt.Rows.Add("India(Uncut)", "High Nech LS", "7", "7279");
dt.Rows.Add("India(Uncut)", "Printed Fleece Bootom", "10", "7167");
dt.Rows.Add("India(Uncut)", "Uncut Cotton Jeans 100%", "0", "0");
dt.Rows.Add("India(Uncut)", "Uncut Jeans", "60", "74204");
dt.Rows.Add("India(Uncut)", "Uncut Sweater", "5", "4832");
dt.Rows.Add("India(Uncut)", "Uncut White Ploy", "5", "5377");
dt.Rows.Add("India(Uncut)", "Uncut Wool Body", "0", "0");
dt.Rows.Add("India(Uncut)", "Uncut Wool Pants", "0", "0");
dt.Rows.Add("India(Uncut)", "Uncut Wool Sweaters 50-100%", "0", "0");
dt.Rows.Add("India(Uncut)", "Uncut Wool Sweaters 60-100%", "0", "0");
dt.Rows.Add("India(Uncut)", "White Socks", "1", "925");
this.gvStock.DataSource = dt;
this.gvStock.DataBind();
}
}
protected void gvStock_DataBound(object sender, EventArgs e)
{
for (int i = rowIndex; i < gvStock.Rows.Count; i++)
{
wbSubTotal += Convert.ToDecimal(gvStock.Rows[i].Cells[gvStock.Rows[i].Cells.Count - 1].Text);
bSubTotal += Convert.ToDecimal(gvStock.Rows[i].Cells[gvStock.Rows[i].Cells.Count - 2].Text);
}
this.AddTotalRow("Sub Total", bSubTotal.ToString("N2"), wbSubTotal.ToString("N2"));
this.AddTotalRow("Total", balanceTotal.ToString("N2"), WBalanceTotal.ToString("N2"));
for (int i = gvStock.Rows.Count - 1; i > 0; i--)
{
GridViewRow row = gvStock.Rows[i];
GridViewRow previousRow = gvStock.Rows[i - 1];
for (int j = 0; j < row.Cells.Count -2; j++)
{
if (row.Cells[j].Text == previousRow.Cells[j].Text && row.Cells[j].Text != "0")
{
if (row.Cells[j].RowSpan == 0)
{
previousRow.Cells[j].RowSpan += 2;
}
else
{
previousRow.Cells[j].RowSpan = row.Cells[j].RowSpan + 1;
}
row.Cells[j].Visible = false;
}
}
}
}
string currentCategory = "";
decimal wbSubTotal = 0;
decimal bSubTotal = 0;
decimal WBalanceTotal = 0;
decimal balanceTotal = 0;
int rowIndex = 0;
protected void OnRowCreated(object sender, GridViewRowEventArgs e)
{
wbSubTotal = 0;
bSubTotal = 0;
if (e.Row.RowType == DataControlRowType.DataRow)
{
DataTable dt = (e.Row.DataItem as DataRowView).DataView.Table;
string category = dt.Rows[e.Row.RowIndex]["Category"].ToString();
balanceTotal += Convert.ToDecimal(dt.Rows[e.Row.RowIndex]["Balance"]);
WBalanceTotal += Convert.ToDecimal(dt.Rows[e.Row.RowIndex]["W_Balance"]);
if (category != currentCategory)
{
if (e.Row.RowIndex > 0)
{
for (int i = rowIndex; i < e.Row.RowIndex; i++)
{
wbSubTotal += Convert.ToDecimal(gvStock.Rows[i].Cells[e.Row.Cells.Count - 1].Text);
bSubTotal += Convert.ToDecimal(gvStock.Rows[i].Cells[e.Row.Cells.Count - 2].Text);
}
this.AddTotalRow("Sub Total", bSubTotal.ToString("N2"), wbSubTotal.ToString("N2"));
rowIndex = e.Row.RowIndex;
}
currentCategory = category;
}
}
}
private void AddTotalRow(string labelText, string balance, string wBalance)
{
GridViewRow row = new GridViewRow(0, 0, DataControlRowType.DataRow, DataControlRowState.Normal);
row.BackColor = ColorTranslator.FromHtml("#F9F9F9");
row.Cells.AddRange(new TableCell[4] {
//new TableCell (), //Empty Cell
//new TableCell (), //Empty Cell
//new TableCell (), //Empty Cell
//new TableCell (), //Empty Cell
new TableCell (), //Empty Cell
new TableCell { Text = labelText, HorizontalAlign = HorizontalAlign.Right },
new TableCell { Text = balance, HorizontalAlign = HorizontalAlign.Right },
new TableCell { Text = wBalance, HorizontalAlign = HorizontalAlign.Right } });
gvStock.Controls[0].Controls.Add(row);
}
VB.Net
Protected Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs) Handles Me.Load
If Not Me.IsPostBack Then
Dim dt As DataTable = New DataTable()
dt.Columns.AddRange(New DataColumn() {New DataColumn("Category"), New DataColumn("Name"), New DataColumn("Balance"), New DataColumn("W_Balance")})
dt.Rows.Add("India(Uncut)", "High Nech LS", "7", "7279")
dt.Rows.Add("India(Uncut)", "Printed Fleece Bootom", "10", "7167")
dt.Rows.Add("India(Uncut)", "Uncut Cotton Jeans 100%", "0", "0")
dt.Rows.Add("India(Uncut)", "Uncut Jeans", "60", "74204")
dt.Rows.Add("India(Uncut)", "Uncut Sweater", "5", "4832")
dt.Rows.Add("India(Uncut)", "Uncut White Ploy", "5", "5377")
dt.Rows.Add("India(Uncut)", "Uncut Wool Body", "0", "0")
dt.Rows.Add("India(Uncut)", "Uncut Wool Pants", "0", "0")
dt.Rows.Add("India(Uncut)", "Uncut Wool Sweaters 50-100%", "0", "0")
dt.Rows.Add("India(Uncut)", "Uncut Wool Sweaters 60-100%", "0", "0")
dt.Rows.Add("India(Uncut)", "White Socks", "1", "925")
Me.gvStock.DataSource = dt
Me.gvStock.DataBind()
End If
End Sub
Protected Sub gvStock_DataBound(sender As Object, e As EventArgs)
For i As Integer = rowIndex To gvStock.Rows.Count - 1
wbSubTotal += Convert.ToDecimal(gvStock.Rows(i).Cells(gvStock.Rows(i).Cells.Count - 1).Text)
bSubTotal += Convert.ToDecimal(gvStock.Rows(i).Cells(gvStock.Rows(i).Cells.Count - 2).Text)
Next
Me.AddTotalRow("Sub Total", bSubTotal.ToString("N2"), wbSubTotal.ToString("N2"))
Me.AddTotalRow("Total", balanceTotal.ToString("N2"), WBalanceTotal.ToString("N2"))
For i As Integer = gvStock.Rows.Count - 1 To 1 Step -1
Dim row As GridViewRow = gvStock.Rows(i)
Dim previousRow As GridViewRow = gvStock.Rows(i - 1)
For j As Integer = 0 To row.Cells.Count - 2 - 1
If row.Cells(j).Text = previousRow.Cells(j).Text Then
If previousRow.Cells(j).RowSpan = 0 Then
If row.Cells(j).RowSpan = 0 Then
previousRow.Cells(j).RowSpan += 2
Else
previousRow.Cells(j).RowSpan = row.Cells(j).RowSpan + 1
End If
row.Cells(j).Visible = False
End If
End If
Next
Next
End Sub
Private currentCategory As String = ""
Private wbSubTotal As Decimal = 0
Private bSubTotal As Decimal = 0
Private WBalanceTotal As Decimal = 0
Private balanceTotal As Decimal = 0
Private rowIndex As Integer = 0
Protected Sub OnRowCreated(ByVal sender As Object, ByVal e As GridViewRowEventArgs)
wbSubTotal = 0
bSubTotal = 0
If e.Row.RowType = DataControlRowType.DataRow Then
Dim dt As DataTable = (TryCast(e.Row.DataItem, DataRowView)).DataView.Table
Dim category As String = dt.Rows(e.Row.RowIndex)("Category").ToString()
balanceTotal += Convert.ToDecimal(dt.Rows(e.Row.RowIndex)("Balance"))
WBalanceTotal += Convert.ToDecimal(dt.Rows(e.Row.RowIndex)("W_Balance"))
If category <> currentCategory Then
If e.Row.RowIndex > 0 Then
For i As Integer = rowIndex To e.Row.RowIndex - 1
wbSubTotal += Convert.ToDecimal(gvStock.Rows(i).Cells(e.Row.Cells.Count - 1).Text)
bSubTotal += Convert.ToDecimal(gvStock.Rows(i).Cells(e.Row.Cells.Count - 2).Text)
Next
Me.AddTotalRow("Sub Total", bSubTotal.ToString("N2"), wbSubTotal.ToString("N2"))
rowIndex = e.Row.RowIndex
End If
currentCategory = category
End If
End If
End Sub
Private Sub AddTotalRow(ByVal labelText As String, ByVal balance As String, ByVal wBalance As String)
Dim row As GridViewRow = New GridViewRow(0, 0, DataControlRowType.DataRow, DataControlRowState.Normal)
row.BackColor = ColorTranslator.FromHtml("#F9F9F9")
row.Cells.AddRange(New TableCell(3) {New TableCell(), New TableCell With {
.Text = labelText,
.HorizontalAlign = HorizontalAlign.Right
}, New TableCell With {
.Text = balance,
.HorizontalAlign = HorizontalAlign.Right
}, New TableCell With {
.Text = wBalance,
.HorizontalAlign = HorizontalAlign.Right
}})
gvStock.Controls(0).Controls.Add(row)
End Sub
Screenshot