C# Winform實(shí)現(xiàn)表格復(fù)制粘貼效果
前言
這是前幾天有粉絲留言咨詢的一個(gè)問題,想實(shí)現(xiàn)在Winform中對(duì)表格數(shù)據(jù)進(jìn)行批量復(fù)制粘貼。我這邊給出的方案就是直接操作數(shù)據(jù)集了,個(gè)人認(rèn)為這種方式是最簡(jiǎn)單的了。其實(shí)我覺得在Winform數(shù)據(jù)表格中,無論是自帶的DataGridView還是其他第三方的Grid控件,大部分情況都可以優(yōu)先考慮通過操作數(shù)據(jù)集來實(shí)現(xiàn),而不要優(yōu)先考慮操作UI,即復(fù)雜又困難。
以下代碼可以在Excel與DataGridView中實(shí)現(xiàn)相互復(fù)制粘貼,目前只是做了一個(gè)效果出來,具體的復(fù)雜情況需要根據(jù)自身需求來做動(dòng)態(tài)調(diào)整。也可部分參考之前寫的一篇:C#實(shí)現(xiàn)表格數(shù)據(jù)轉(zhuǎn)實(shí)體
1.先說下實(shí)現(xiàn)原理,其實(shí)可以觀察Excel的復(fù)制數(shù)據(jù),即把Excel復(fù)制兩行數(shù)據(jù)粘貼到記事本中,會(huì)發(fā)現(xiàn)列與列之間是通過制表符來區(qū)分的,而行與行之間就是換行符了。
2.得到這個(gè)結(jié)果就可以直接處理粘貼板數(shù)據(jù)了,只要按照上面的格式進(jìn)行字符串拼接或者拆分就行
3.接下來看下實(shí)現(xiàn)代碼,首先隨便定義一個(gè)實(shí)體類用來綁定數(shù)據(jù)源,然后添加幾行測(cè)試數(shù)據(jù)
private class Model
{
public int ID { get; set; }
public string Name { get; set; }
}
BindingList<Model> BindData=new BindingList<Model>();
private void Form1_Load(object sender, EventArgs e)
{
BindData.Add(new Model { ID=1,Name="張三"});
BindData.Add(new Model { ID = 2, Name = "李四" });
BindData.Add(new Model { ID = 3, Name = "王五" });
gridViewEx1.DataSource = BindData;
}4.在KeyDown事件中處理復(fù)制粘貼的數(shù)據(jù),即Ctrl+C與Ctrl+V
private void gridViewEx1_KeyDown(object sender, KeyEventArgs e)
{
if (e.Control && e.KeyCode == Keys.C)
{
string data = "";
var rows = gridViewEx1.SelectedRows;
foreach (DataGridViewRow row in rows)
{
foreach (DataGridViewColumn column in gridViewEx1.Columns)
{
data += row.Cells[column.Name] + "\t";
}
data += "\r";
}
Clipboard.SetText(data);
Layer.Success("復(fù)制成功");
}
if (e.Control && e.KeyCode == Keys.V)
{
string data = Clipboard.GetText();
string[] rows = data.Split(new string[] { "\r\n"},StringSplitOptions.RemoveEmptyEntries);
foreach (string row in rows)
{
string[] columns = row.Split('\t');
BindData.Add(new Model { ID = Convert.ToInt32(columns[0]), Name = columns[1] });
}
Layer.Success("粘貼成功");
}
}5. 最后來看看效果

到此這篇關(guān)于C# Winform實(shí)現(xiàn)表格復(fù)制粘貼效果的文章就介紹到這了,更多相關(guān)C# Winform復(fù)制粘貼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#利用反射實(shí)現(xiàn)多數(shù)據(jù)庫訪問
本文詳細(xì)講解了C#利用反射實(shí)現(xiàn)多數(shù)據(jù)庫訪問的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
C#客戶端HttpClient請(qǐng)求認(rèn)證及數(shù)據(jù)傳輸
本文詳細(xì)講解了C#客戶端HttpClient請(qǐng)求認(rèn)證及數(shù)據(jù)傳輸,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-01-01
C# 9.0新特性——擴(kuò)展方法GetEnumerator支持foreach循環(huán)
這篇文章主要介紹了C# 9.0新特性——擴(kuò)展方法GetEnumerator支持foreach循環(huán)的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)c# 9.0,感興趣的朋友可以了解下2020-11-11
C#實(shí)現(xiàn)ListView選中項(xiàng)向上或向下移動(dòng)的方法
這篇文章主要介紹了C#實(shí)現(xiàn)ListView選中項(xiàng)向上或向下移動(dòng)的方法,通過兩個(gè)按鈕點(diǎn)擊事件實(shí)現(xiàn)ListView選中項(xiàng)的上下移動(dòng)功能,需要的朋友可以參考下2015-06-06
Winform實(shí)現(xiàn)將網(wǎng)頁生成圖片的方法
這篇文章主要介紹了Winform實(shí)現(xiàn)將網(wǎng)頁生成圖片的方法,類似于一般瀏覽器自帶的網(wǎng)頁生成圖片的功能,需要的朋友可以參考下2014-09-09

