C#实现WinForm下DataGridView控件从剪切板中进行内容粘贴

DataGridView是C#中在处理显示表格数据时常用的控件,但是在使用过程中,会发现复制DataGridView控件中的内容比较容易,而把剪切板中拷贝的内容黏贴到DataGridView控件中比较复杂,下面用一种简单的方式实现复制功能:

代码如下:
DataGridView的KeyDown事件+黏贴数据方法

        /// <summary>
        /// DataGridView的KeyDown事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void dgv_KeyDown(object sender, KeyEventArgs e)
        {
            //判断是否按下:Ctrl+V
            if (Control.ModifierKeys == Keys.Control && e.KeyCode == Keys.V)
            {
                //对象不为null,且对象为DataGridView类型
                if (sender != null && sender.GetType() == typeof(DataGridView))
                    DataGirdViewCellPaste((DataGridView)sender);//调用黏贴方法
            }
        }
        /// <summary>
        /// 向DataGridView控件粘贴数据
        /// </summary>
        public void DataGirdViewCellPaste(DataGridView dgv)
        {
            if (dgv.CurrentCell == null)//判断当前单元格已选中,复制黏贴单元格初始位置
                return;
            int insertRowIndex = dgv.CurrentCell.RowIndex;//获取当前单元格行索引,打印单元格内容调用
            int insertColIndex = dgv.CurrentCell.ColumnIndex;//获取当前单元格列索引,打印单元格内容调用

            string pasteText = Clipboard.GetText();//获取当前剪切板的内容(黏贴内容必须是表格形式)
            if (string.IsNullOrEmpty(pasteText))//剪贴板内容不为空
                return;

            #region 获取剪贴板内容的行、列数
            //剪切板内容:21\t\t\r\n11\t12\r\n(\t:表示空格;\r\n:表示换行)
            #region 获取行数
            char[] c = pasteText.ToCharArray();//化整为零,将字符串转化成字符数组,逐个遍历
            int RowCount = 0;//行数初始为零
            for (int i = 0; i < c.Length; i++)
            {
                if (c[i] == '\n')//根据"\r\n"中的'\n'获取换行次数,从而获取总行数
                {
                    RowCount++;
                }
            }
            //判断复制范围是否在最大行范围内:(黏贴内容行数-1)+(当前单元格行索引值+1) > 表格总行数
            //(黏贴内容行数 -1):因为有一行刚好黏贴在当前行
            if (RowCount + insertRowIndex > dgv.RowCount)
            {
                MessageBox.Show("粘贴的行数不正确");
                return;
            }
            #endregion

            #region 获取列数
            string[] s = pasteText.Split(new char[] { '\r', '\n' });//根据'/r'、'/n',把数据分为行单位内容
            string[] Col = s[0].Split('\t');//根据'\t',获取每行单元格数,也就是列数
            int ColCount = Col.Length;//列数
            //判断复制范围是否在最列行范围内:(黏贴内容列数-1)+(当前单元格列索引值+1) > 表格总列数
            if (ColCount + insertColIndex > dgv.ColumnCount)
            {
                MessageBox.Show("粘贴的列数不正确");
                return;
            }
            #endregion

            #endregion

            #region 黏贴单元格内容
            List<string> listRow = new List<string>();//声明集合,存储行单位内容
            for (int i = 0; i < s.Length; i++)
            {
                if (s[i] != "")//存储不为null的行单位内容
                {
                    listRow.Add(s[i]);
                }
            }
            //黏贴单元格内容到表格上
            for (int iR = 0; iR < RowCount; iR++)
            {
                for (int iC = 0; iC < ColCount; iC++)
                {
                    //注意黏贴单元格索引位置:在当前单元格的初始索引上叠加
                    dgv[iC + insertColIndex, iR + insertRowIndex].Value = listRow[iR].Split('\t')[iC];
                    // listRow[iR]:第[iR+1]行单元格内容
                    // listRow[iR].Split('\t'):把第[iR+1]行单元格内容划分
                    // listRow[iR].Split('\t')[iC]:提取第[iR+1]行的第[iC+1]个单元格内容
                }
            }
            #endregion
        }

*注意:此方法目前只测试了,从Excel或是Word的表格向DataGridView控件粘贴内容

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值