1. 需要实现类似于Excel的功能,就是在任意位置选中鼠标起点和终点所连对角线所在的矩形,进行复制粘贴。

2. 要实现这个功能,首先需要获取鼠标起点和终点点击的位置。

3. 所以通过GridView(我用的是dev这款插件)的MouseDown和MouseUp事件来获取这连个位置。MouseDown获得鼠标左键按下时的所在的行列信息,MouseUp获得鼠标左键抬起时的行列信息。然后简单加减法计算一共选中的行数和列数。

有了这个思路代码其实挺简单的。今天没时间了,明天贴代码。

----------------------------------------------------------------------------------------------

粘贴部分的代码

try
{
string pasteText = Clipboard.GetText().Replace("\r\n", "@").TrimEnd('@');//得到剪切板里的信息
string[] Row = pasteText.Split('@');//分割的行数数组
string[] col = Row[].Replace("\t", "#").TrimEnd('#').Split('#');//列数数组
//判断是否存在非数字类型
Regex rgx = new Regex(@"^[-]?\d+[.]?\d*$");
for (int t = ; t < Row.Length; t++)
{
col = Row[t].Replace("\t", "#").TrimEnd('#').Split('#');
for (int t1 = ; t1 < col.Length; t1++)
{
//判断字符串
if (!rgx.IsMatch(col[t1].ToString().Trim()))
{
XtraMessageBox.Show("粘贴的内容存在非数字类型!");
return;
}
}
} int _iRowCount = gridRowHandleEnd - gridRowHandleStar + ;//一共选择的行数
int _iColCount = gridColHandleEnd - gridColHandleStar + ;//一共选择的列数
for (int r = ; r < Row.Length; r++)
{
//获取每行中的内容
string rowMessage = Row[r].Replace("\t", "#").TrimEnd('#');
col = rowMessage.Split('#');
DataRow dr = dtInputSurveyData.Rows[gridRowHandleStar + r];//r是从0开始的,gridRowHandleStar+r的作用等同于gridRowHandleStar++
//判断外部复制内容的列数GridView中选中内容的列数的大小,最终粘贴内容的列数应与小的相同;
if (_iColCount < col.Length)
{
for (int i = ; i < _iColCount; i++)
{
dr[gridColHandleStar + i] = col[i];
}
}
else
{
for (int i = ; i < col.Length; i++)
{
dr[gridColHandleStar + i] = col[i];
}
}
}
}
catch (Exception ex)
{
XtraMessageBox.Show(ex.Message, Properties.Resources.ErrorTitle);
}

还需要在gridview的MouseDown和MouseUp事件中添加代码来获取鼠标按下和抬起时的位置(我这里用的是dev这款插件,所以我这里的gridview是gridcontrol 下的gridview)。

MouseDown:

try
{
//当鼠标按下时获取当前点击cell的位置信息
GridHitInfo _gridHI = gvInputSurveyData.CalcHitInfo(e.Location);
if (e.Button == MouseButtons.Left && _gridHI.RowHandle >= )
{
gridColHandleStar = _gridHI.Column.ColumnHandle;
gridRowHandleStar = _gridHI.RowHandle;
}
}
catch (Exception ex)
{
XtraMessageBox.Show(ex.Message, Properties.Resources.ErrorTitle);
}

MouseUp:

            GridHitInfo _gridHI = gvInputSurveyData.CalcHitInfo(e.Location);
if (e.Button == MouseButtons.Left && _gridHI.RowHandle >= )
{
gridColHandleEnd = _gridHI.Column.ColumnHandle;
gridRowHandleEnd = _gridHI.RowHandle;
}

这里两个Start 变量和两个end变量都是全局的,用来保存鼠标起始和终止的行列信息。

感谢您的阅读,不足之处请见谅。期待与您在评论区交流。

C# WinForm:DataTable中数据复制粘贴操作的实现的更多相关文章

  1. Android中的复制粘贴

    Android中的复制粘贴 The Clipboard Framework 当使用clipboard framework时,把数据放在一个剪切对象(clip object)里,然后这个对象会放在系统的 ...

  2. Excel 2010 如何将筛选后的数据复制粘贴到另一个工作表筛选后的表格里

    如果你是指自动筛选后,把筛选数据复制/粘贴到另外一个工作表中,不妨试试试 第一步选中筛选后的数据区域:第二步执行菜单命令“编辑/定位/定位条件/可见单元格”,确定:第三步单击复制按钮或者Ctrl+C或 ...

  3. Ubuntu的复制粘贴操作及常用快捷键(摘自网络)

    Ubuntu的复制粘贴操作 终端最大化快捷键:crtl + win + 上 1.最为简单,最为常用的应该是鼠标右键操作了,可以选中文件,字符等,右键鼠标,复制,到目的地右键鼠标,粘贴就结束了. 2.快 ...

  4. ubuntu18.04下取消中键复制粘贴功能

    Q: armlinux开发,主机采用ubuntu18.04操作系统,使用过程中关于鼠标中键有如下操作现象, 操作: 1.选中文本, 2.将鼠标光标定位到要插入的位置 3.按下鼠标中键 现象:将自动复制 ...

  5. 在CMD命令行和PowerShell中实现复制粘贴功能

    在CMD命令行和PowerShell中实现复制粘贴功能         常常使用命令行或者PowerShell的朋友肯定会遇到这样的情况:粘贴文本非常easy,右键--选择粘贴就可以,可是想要复制命令 ...

  6. [转]怎样在cmd(命令提示符)下进行复制粘贴操作

    原文链接:http://jingyan.baidu.com/article/93f9803fd3a4dde0e46f55f5.html cmd下复制粘贴的快捷操作方式 工具/原料 系统cmd 步骤/方 ...

  7. Eclipse/MyEclipse中使用复制粘贴功能卡的解决办法

    最近在MyEclipse中编辑代码时,使用快捷键进行复制粘贴,经常会导致编辑器短暂的停顿,光标不跟随,居然反应不过来,几近假死. 想来想去应该是编辑上的什么配置或者是IDE的什么功能导致,于是进入Pr ...

  8. C#把DataTable中数据一次插入数据库的方法

    现在实际的情况是这样的: 客户有一台打卡机,员工打卡的信息全部储存在打卡机的Access数据库里面,现在客户引入了一种新的管理系统,需要将Access数据库中的打卡数据同步到SQL Server数据库 ...

  9. SqlServer将表中数据复制到另一张表

    insert into phone2(ph,attr,type,carrier) select top 1000 ph,attr,type,carrier from phone 将表phone的字段和 ...

随机推荐

  1. 基于WebGL/Threejs技术的BIM模型轻量化之图元合并

    伴随着互联网的发展,从桌面端走向Web端.移动端必然的趋势.互联网技术的兴起极大地改变了我们的娱乐.生活和生产方式.尤其是HTML5/WebGL技术的发展更是在各个行业内引起颠覆性的变化.随着WebG ...

  2. #10038.A Horrible Poem

    #10038.A Horrible Poem 题目传送门 思路解析 既然这道题目在hash板块里,那么自然就可以想到用hash做这道题目. 首先我们可以用hash数组存储字符串的前缀的hash值. 因 ...

  3. Python——IPython和NumPy

    IPython: 一个增强的Python shell:许多python对象的显示形式更友好.更详细的异常显示.增加额外的命令交互式数据处理 Tab键自动完成: 键入一些内容之后,按Tab键,显示可能的 ...

  4. mysql-视图、触发器、事务、存储过程、流程控制

    目录 视图 触发器 事务 存储过程 流程控制 一.视图 视图是由查询结果构成的一张虚拟表,和真实的表一样,带有名称的列和行数据 强调:视图是永久存储的,但是视图存储的不是数据,只是一条sql语句 视图 ...

  5. maven的配置-2019-4-13

    一.Maven的优点 1.  依赖管理 jar 包管理 2.一键构建 (编译-----测试------打包-----安装-----部署 ) 什么是项目构建? 指的是项目从编译-----测试------ ...

  6. springboot 中页面跳转问题:window.location.href

    我的一个HTML页面 点击注册 本该到注册页面,但是却一直跳到同目录的一个Error.html文件夹下 该页面: 删掉Error.html还不行:会报错,而且改变window.location.hre ...

  7. Java 基本语法,标识符,修饰符,关键字

    基本语法 编写 Java 程序时,应注意以下几点: 大小写敏感:Java 是大小写敏感的,这就意味着标识符 Hello 与 hello 是不同的. 类名:对于所有的类来说,类名的首字母应该大写.如果类 ...

  8. OpenStack--ntp组件时间同步服务

    作用:ntp主要是用于对计算机的时间同步管理操作 环境: 服务端: 192.168.245.172 客户端: 192.168.245.171 时间是对服务器来说是很重要的,一般很多网站都需要读取服务器 ...

  9. Linux 常用命令介绍

    介绍常用命令,在忘记时便于即使查询 复制.移动.删除     cp.mv.rm.pwd 1. CP 介绍 用法:CP [-adfilprsu]  源文件  目标文件 参数:参数说明: -a:是指arc ...

  10. chrome启动参数之

    --remote-debugging-port Chrome 启动的时候,默认是关闭了调试端口的,如果要对一个目标 Chrome PC 浏览器进行调试,那么启动的时候,可以通过传递参数来开启 Chro ...