Winform-DataGridView 实现如Excel的粘贴复制
void AddDataGridView(DataGridView gridView, string s)
{
s = s.Replace("/", @"\"); //避免因为版本造成的斜杠问题,这里做统一处理
int RowCount = (s.Length - s.Replace("\r\n", "").Length) / 2 + 1; //最终计算结果,这次覆盖所要影响的行数 /r/n只占2个字节所以是除2
int CellCount = (s.Length - s.Replace("\t", "").Length + RowCount) / RowCount; ; //~每行单元格数 /t的数量加行数=所有单元格数(第一个单元格会不计算)
string[,] Strarr = new string[RowCount, CellCount]; //用于记录复制的单元格信息的二维数组
for (int i = 0; i < RowCount; i++) //将单元格信息添加到数组中
{
string tem_s = s.Split(new string[] { "\r\n" }, StringSplitOptions.None)[i];
for (int j = 0; j < CellCount; j++)
{
Strarr[i, j] = tem_s.Split(new string[] { "\t" }, StringSplitOptions.None)[j];
}
}
//获取选择单元格 以第一个单元格为0点向第四象限扩展 SelectedCells是以用户选择顺序或者拖动方向决定的 是不规律的
//为了保证和理性,这里所取的第一个单元格是左上角的单元格
int arrayX = 0, arrayY = 0; //二维数组坐标系
int startRow = gridView.Rows.Count, startColumn = gridView.ColumnCount; //起始的单元格坐标系
foreach (DataGridViewCell cell in gridView.SelectedCells) //迭代比较,获取2轴数字均最小的坐标
{
startRow = cell.RowIndex < startRow ? cell.RowIndex : startRow;
startColumn = cell.ColumnIndex < startColumn ? cell.ColumnIndex : startColumn;
}
for (int i = startRow; (arrayX < RowCount && i < gridView.Rows.Count); i++, arrayX++) //非空验证
{
arrayY = 0;
DialogResult dr=new DialogResult();
for (int j = startColumn; (arrayY < CellCount && j < gridView.ColumnCount); j++, arrayY++)
{
if (!string.IsNullOrEmpty(gridView.Rows[i].Cells[j].Value.ToString()))
{
dr = MessageBox.Show("继续操作会覆盖原内容!", "警告", MessageBoxButtons.OKCancel);
if (dr == DialogResult.OK)
break; //单元格非空时警示,确定操作退出循环继续赋值
else
return; //否则直接返回方法
}
}
if (dr == DialogResult.OK) //如果做了选择 则退出
break;
}
arrayX = arrayY = 0; //坐标系重置
for (int i = startRow; (arrayX < RowCount && i < gridView.Rows.Count); i++, arrayX++) //数据赋值
{
arrayY = 0;
for (int j = startColumn; (arrayY < CellCount && j < gridView.ColumnCount); j++, arrayY++)
{
gridView.Rows[i].Cells[j].Value = Strarr[arrayX, arrayY];
}
}
}
如果不需要覆盖检查,代码会简短一些
Winform-DataGridView 实现如Excel的粘贴复制的更多相关文章
- winform DataGridView 导出到Excel表格 分类: WinForm 2014-07-04 10:48 177人阅读 评论(0) 收藏
public bool ExportDataGridview(DataGridView gridView) { if (gridView.Rows.Count ...
- Winform DataGridView直接导出Excel
/// <summary> /// 导出excel /// </summary> /// <param name="fileName">导出文件 ...
- [WinForm]dataGridView导出到EXCEL
方法一: SaveFileDialog dlg = new SaveFileDialog(); dlg.Filter = "Execl files (*.xls)|*.xls"; ...
- C# winform DataGridView 常见属性
C# winform DataGridView 属性说明① 取得或者修改当前单元格的内容 ② 设定单元格只读 ③ 不显示最下面的新行 ④ 判断新增行 ⑤ 行的用户删除操作的自定义 ⑥ 行.列的隐藏和删 ...
- 关于C# Winform DataGridView 设置DefaultCellStyle无效的原因与解决方案
上周在开发Winform 项目中,我曾遇到一个看似简单,但一直都没有解决的问题,那就是:设置winform DataGridView控件的行DefaultCellStyle,但却没有任何变化,我也曾求 ...
- 从 Excel 表格粘贴到 浏览器表格中
从 Excel 表格粘贴到 浏览器表格中 由于 Excel 用途广泛,所以在导入时用到很多. 但是更多人的喜欢使用复制粘贴. 在网上找了一圈有找到一个开源项目,可以将 Excel 粘贴到 HTML 中 ...
- 在Excel中粘贴时怎样跳过隐藏行
http://www.excel123.cn/Article/exceljichu/201203/932.html 有时在筛选后需要将其他区域中的连续行数据复制粘贴到筛选区域,以替换筛选后的数据.由于 ...
- js屏蔽浏览器右键菜单,粘贴,复制,剪切,选中(转)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- DataGridView导出到Excel的三个方法
#region DataGridView数据显示到Excel /// <summary> /// 打开Excel并将DataGridView控件中数据导出到Excel /// </s ...
随机推荐
- ubuntu快捷复制粘贴
今天使用putty,纠结复制粘贴的时候,才发现 原来只要选中文本后,就可以中键粘贴 整个桌面环境可用,新技能啊以前居然不知道
- ES6 ( 三 ) 字符串扩展
一.字符Unicode表示方法 ES6中可以使用以下6种方法表示字符 '\z' === 'z' // true '\172' === 'z' // true '\x7A' === 'z' // tru ...
- 使用 SVN Hook 实现服务器端代码自动更新
之前的做法是客户端提交代码之后,再去服务器端项目中 svn up 一下来更新代码,让服务器端的项目更新到最新版本.可以编写一个 post-commit 钩子脚本来实现服务器端代码的自动更新,它在 SV ...
- Android开发使用TotalControl调试遇到的问题(备注)
背景:Android开发,使用TotalControl控制手机进行调试. 过程:Eclipse调试一直正常,某天下午突然提示:无法启动ADB.exe,请确认是否在对应的路径下. 怀疑是自己程序写的有问 ...
- django对数据查询结果进行排序的方法
在你的 Django 应用中,你或许希望根据某字段的值对检索结果排序,比如说,按字母顺序. 那么,使用 order_by() 这个方法就可以搞定了. ? 1 2 >>> Publis ...
- iscoll制作顶部可以左右滑动的tab
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...
- c语言文法简化版文法
<源程序>→<外部声明>|<外部声明><函数体> <外部申明>→<头文件><函数声明>|其他声明 <函数体&g ...
- ssl双向认证和单向认证原理
有朋友在搞一个项目,周末有聊到一些安全性的东西,很自然会想起https,但https究竟如何实施,其原理又是什么? 基于ssl,一般的应用都是单向认证,如果应用场景要求对客户来源做验证也可以实现成双向 ...
- CSS中定位和浮动对行内元素的宽高的影响
行内元素的大小是由元素里面的内容撑开的宽高决定的,就算在css中对行内元素设置width,height.行内元素也会忽略宽高的设置. 但是当行内元素使用position:absolute或者posit ...
- php代码性能分析方法
1.用到的函数 microtime() ,函数返回当前 Unix 时间戳和微秒数,本函数以 "msec sec" 的格式返回一个字符串,其中 sec 是自 Unix 纪元(0:00 ...