[C#]合并单元格(行、列)
详细链接:https://shop499704308.taobao.com/?spm=a1z38n.10677092.card.11.594c1debsAGeak
説明:控件ID指的是页面上面的GridView控件的ID名称或者是DataGrid控件的ID名称; 控件类型写GridView或者DataGrid(根据页面控件属于那种就写那种)。 如有疑问请留言。。。。。。。 /// <summary>
/// 合并单元格(合并某一行的所有列)
/// </summary>
/// <param name="id">控件的ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="rows">需要合并的行</param>
public static void GroupRow(string id,string type, int rows)
{
Control contr = new Control();
TableCell oldTc = null;
switch(type)
{
case "GridView":
GridView GridView1 = (GridView)contr.FindControl(id);
oldTc = GridView1.Rows[rows].Cells[];
for (int i = ; i < GridView1.Rows[rows].Cells.Count; i++)
{
TableCell tc = GridView1.Rows[rows].Cells[i]; //Cells[0]就是你要合并的列
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.ColumnSpan == )
{
oldTc.ColumnSpan = ;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
break;
case "DataGrid":
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
oldTc = DataGrid1.Items[rows].Cells[];
for (int i = ; i < DataGrid1.Items[rows].Cells.Count; i++)
{
TableCell tc = DataGrid1.Items[rows].Cells[i]; //Cells[0]就是你要合并的列
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.ColumnSpan == )
{
oldTc.ColumnSpan = ;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
break;
}
} /// <summary>
/// 合并单元格(合并一行中的几列)
/// </summary>
/// <param name="id">控件ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="rows">行</param>
/// <param name="sCol">开始列</param>
/// <param name="eCol">结束列</param>
public static void GroupRow(string id, string type, int rows, int sCol, int eCol)
{
Control contr = new Control();
TableCell oldTc = null;
switch (type)
{
case "GridView":
GridView GridView1 = (GridView)contr.FindControl(id);
oldTc = GridView1.Rows[rows].Cells[sCol];
for (int i = ; i < eCol - sCol; i++)
{
TableCell tc = GridView1.Rows[rows].Cells[i + sCol]; //Cells[0]就是你要合并的列
tc.Visible = false;
if (oldTc.ColumnSpan == )
{
oldTc.ColumnSpan = ;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
case "DataGrid":
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
oldTc = DataGrid1.Items[rows].Cells[sCol];
for (int i = ; i < eCol - sCol; i++)
{
TableCell tc = DataGrid1.Items[rows].Cells[i + sCol]; //Cells[0]就是你要合并的列
tc.Visible = false;
if (oldTc.ColumnSpan == )
{
oldTc.ColumnSpan = ;
}
oldTc.ColumnSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
}
} /// <summary>
/// 合并单元格(合并某一列所有行)
/// </summary>
/// <param name="id">控件ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="cols">需要合并的列</param>
public static void GroupCol(string id, string type, int cols)
{
Control contr = new Control();
if (type == "GridView")
{
GridView GridView1 = (GridView)contr.FindControl(id); if (GridView1.Rows.Count < || cols > GridView1.Rows[].Cells.Count - )
{
return;
}
TableCell oldTc = GridView1.Rows[].Cells[cols];
for (int i = ; i < GridView1.Rows.Count; i++)
{
TableCell tc = GridView1.Rows[i].Cells[cols];
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.RowSpan == )
{
oldTc.RowSpan = ;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
}
else
{
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id); if (DataGrid1.Items.Count < || cols > DataGrid1.Items[].Cells.Count - )
{
return;
}
TableCell oldTc = DataGrid1.Items[].Cells[cols];
for (int i = ; i < DataGrid1.Items.Count; i++)
{
TableCell tc = DataGrid1.Items[i].Cells[cols];
if (oldTc.Text == tc.Text)
{
tc.Visible = false;
if (oldTc.RowSpan == )
{
oldTc.RowSpan = ;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
else
{
oldTc = tc;
}
}
}
} /// <summary>
/// 合并单元格(合并某一列中的某些行)
/// </summary>
/// <param name="id">控件ID</param>
/// <param name="type">控件类型对象(如写GridView,DataGrid)</param>
/// <param name="cols">列</param>
/// <param name="sRow">开始行</param>
/// <param name="eRow">结束列</param>
public static void GroupCol(string id, string type, int cols, int sRow, int eRow)
{
Control contr = new Control();
TableCell oldTc = null;
switch(type)
{
case "GridView":
GridView GridView1 = (GridView)contr.FindControl(id);
if (GridView1.Rows.Count < || cols > GridView1.Columns.Count - )
{
return;
}
oldTc = GridView1.Rows[sRow].Cells[cols];
for (int i = ; i < eRow - sRow; i++)
{
TableCell tc = GridView1.Rows[sRow + i].Cells[cols];
tc.Visible = false;
if (oldTc.RowSpan == )
{
oldTc.RowSpan = ;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
case "DataGrid":
DataGrid DataGrid1 = (DataGrid)contr.FindControl(id);
if (DataGrid1.Items.Count < || cols > DataGrid1.Columns.Count - )
{
return;
}
oldTc = DataGrid1.Items[sRow].Cells[cols];
for (int i = ; i < eRow - sRow; i++)
{
TableCell tc = DataGrid1.Items[sRow + i].Cells[cols];
tc.Visible = false;
if (oldTc.RowSpan == )
{
oldTc.RowSpan = ;
}
oldTc.RowSpan++;
oldTc.VerticalAlign = VerticalAlign.Middle;
}
break;
default:
break;
}
}
[C#]合并单元格(行、列)的更多相关文章
- poi导出excel合并单元格(包括列合并、行合并)
1 工程所需jar包如下:commons-codec-1.5.jarcommons-logging-1.1.jarlog4j-1.2.13.jarjunit-3.8.1.jarpoi-3.9-2012 ...
- DataGridView合并单元格(一列或一行)
#region"合并单元格的测试(一列或一行)" // int?是搜索一种类型(可空类型),普通的int不能为null,而用int?,其值可以为null //private int ...
- Java导出Excel表,POI 实现合并单元格以及列自适应宽度(转载)
POI是apache提供的一个读写Excel文档的开源组件,在操作excel时常要合并单元格,合并单元格的方法是: sheet.addMergedRegion(new CellRangeAddress ...
- POI 实现合并单元格以及列自适应宽度
POI是apache提供的一个读写Excel文档的开源组件,在操作excel时常要合并单元格,合并单元格的方法是: sheet.addMergedRegion(new CellRangeAddress ...
- EasyUi 合并单元格占列显示
$("#TableContainer").datagrid({ url: '', method: "get&q ...
- jquery操作表格 合并单元格
jquery操作table,合并单元格,合并相同的行 合并的方法 $("#tableid").mergeCell({ cols:[X,X] ///参数为要合并的列}) /** * ...
- 【记录】解析具有合并单元格的Excel
最近公司让做各种数据表格的导入导出,就涉及到电子表格的解析,做了这么多天总结一下心得. 工具:NOPI 语言:C# 目的:因为涉及到导入到数据库,具有合并单元格的多行必然要拆分,而NPOI自动解析的时 ...
- 【开发者笔记】解析具有合并单元格的Excel
最近公司让做各种数据表格的导入导出,就涉及到电子表格的解析,做了这么多天总结一下心得. 工具:NOPI 语言:C# 目的:因为涉及到导入到数据库,具有合并单元格的多行必然要拆分,而NPOI自动解析的时 ...
- 个人永久性免费-Excel催化剂功能第52波-相同内容批量合并单元格,取消合并单元格并填充内容
在高级Excel用户群体中无比痛恨的合并单元格,在现实的表格中却阴魂不散的纠缠不断.今天Excel催化剂也来成为“帮凶”,制造更多的合并单元格.虽然开发出此功能,请使用过程中务必要保持节制,在可以称为 ...
随机推荐
- Redis实战——Redis的pub/Sub(订阅与发布)在java中的实现
借鉴:https://blog.csdn.net/canot/article/details/51938955 1.什么是pub/sub Pub/Sub功能(means Publish, Subscr ...
- Oracle11gr2_ADG管理之switchover补充
之前演示的switchver总是提示下面的错误,并且需要人工干预: Oracle11gr2_ADG管理之switchover实战 DGMGRL> switchover to snewtest; ...
- ATL接口返回类型&&ATL接口返回字符串BSTR*
感觉在ATL中做COM组件,添加方法的时候,其返回值只能是HRESULT,我想返回其他数据类型,可以吗? 非也非也 HRESULT指示返回的状态,即正确与否, 返回值是这样的 HRESULT MyMe ...
- Struts2 的核心、执行原理
转自: http://www.cnblogs.com/xiadongqing/p/5240615.html 在学习struts2之前,首先我们要明白使用struts2的目的是什么?它能给我们带来什么样 ...
- Python中的列表生成式和多层表达式
Python中的列表生成式和多层表达式 如何生成[1x1, 2x2, 3x3, ..., 10x10]的列表? L=[]; ,): L.append(x*x) print L print (" ...
- js中格式化时间
//时间格式化 Date.prototype.Format = function (fmt) { var o = { "M+": this.getMonth() + 1, &quo ...
- laravel phpstorm IDE 代码提示
第一步:在项目的composer.json中添加如下一行 "require": { "laravel/framework": "5.0.*" ...
- int类型与char类型的转换
---------siwuxie095 Java对char类型的数据在底层是按int类型来处理的 (只是显示出来仍然是字符型) 1.int类型与char ...
- AlienWare
https://www.chiphell.com/thread-1705089-1-1.html AlienWare
- TFS(Visual Studio Team Services) git认证失败 authentication fails 的解决方案
问题描述 TFS 在visual studio中使用正常,可是git pull运行失败,提示 authentication fails. 初步判断原因为默认的 credential.helper 与 ...