C# Winform實(shí)現(xiàn)導(dǎo)出DataGridView當(dāng)前頁(yè)以及全部數(shù)據(jù)
前言
基本上,所有的業(yè)務(wù)系統(tǒng)都會(huì)要求有導(dǎo)出的功能,很多人會(huì)選擇在每個(gè)列表頁(yè)加入導(dǎo)出按鈕進(jìn)行導(dǎo)出;其實(shí),個(gè)人感覺挺麻煩的。不知道有多少用過Dev控件的,Dev的GridView控件自帶導(dǎo)出功能有沒有覺得很好用?這一篇就動(dòng)手實(shí)現(xiàn)原生DataGridView的導(dǎo)出功能。
實(shí)現(xiàn)
1.新建一個(gè)自定義控件繼承自DataGridView,并在其中定義以下屬性
[Description("可導(dǎo)出的最大數(shù)量")] public int ExportMaxCount { get; set; } = 5000;
2.由于是要讓DataGridView自帶導(dǎo)出控件,所以這里使用右鍵菜單來做,并在OnCreateControl事件中進(jìn)行導(dǎo)出的具體實(shí)現(xiàn)。
ContextMenuStrip contextMenuStrip = new ContextMenuStrip(); protected override void OnCreateControl() { base.OnCreateControl(); contextMenuStrip.Items.Add(new ToolStripMenuItem("導(dǎo)出當(dāng)前頁(yè)", null, (s, e) => { if (Rows.Count == 0) { FrmDialog.ShowMessage("沒有數(shù)據(jù)", "提示"); return; } SaveFileDialog saveFileDialog = new SaveFileDialog(); saveFileDialog.Filter = "Excel文件|*.xlsx"; if (saveFileDialog.ShowDialog() == DialogResult.OK) { DataTable dt = new DataTable(); foreach (DataGridViewColumn column in Columns) { dt.Columns.Add(new DataColumn { ColumnName = column.DataPropertyName, Caption = column.HeaderText }); } foreach (DataGridViewRow dr in Rows) { DataRow dataRow = dt.NewRow(); for (int i = 0; i < dt.Columns.Count; i++) { dataRow[i] = dr.Cells[i].Value; } dt.Rows.Add(dataRow); } ExcelUtils.Export(dt, saveFileDialog.FileName); if (MessageBox.Show("導(dǎo)出成功,是否打開?", "提示", MessageBoxButtons.YesNo) == DialogResult.Yes) { Process.Start(saveFileDialog.FileName); } } })); this.ContextMenuStrip = contextMenuStrip;
3.導(dǎo)出是使用NPOI來實(shí)現(xiàn)的,具體代碼如下,也可參考之前的導(dǎo)出文章
public static void Export(DataTable dataSource, string fileName) { IWorkbook workbook = new XSSFWorkbook(); ISheet sheet = workbook.CreateSheet("sheet1"); IRow rowHead = sheet.CreateRow(0); for (int j = 0; j < dataSource.Columns.Count; j++) { rowHead.CreateCell(j).SetCellValue(dataSource.Columns[j].Caption); } for (int i = 0; i < dataSource.Rows.Count; i++) { IRow row = sheet.CreateRow(i + 1); for (int j = 0; j < dataSource.Columns.Count; j++) { row.CreateCell(j).SetCellValue(Convert.ToString(dataSource.Rows[i][j])); } } using (FileStream fs = new FileStream(fileName, FileMode.OpenOrCreate, FileAccess.ReadWrite)) { workbook.Write(fs); } workbook.Close(); }
4.到這里,其實(shí)就實(shí)現(xiàn)了一個(gè)公用的帶導(dǎo)出功能的DataGridView控件,但是我們一般都會(huì)對(duì)數(shù)據(jù)進(jìn)行分頁(yè)顯示,也會(huì)有導(dǎo)出全部的功能,這就要重新去獲取服務(wù)端的全部數(shù)據(jù)(這里也可以由后端直接生成提供下載地址)。所以我們?cè)诳丶行枰黾右粋€(gè)導(dǎo)出全部的事件,如果對(duì)事件進(jìn)行了注冊(cè)的話,可以在OnMouseDown事件中重新添加一個(gè)導(dǎo)出全部的右鍵菜單,并且可以觸發(fā)該事件。
public EventHandler ExportAllData; protected override void OnMouseDown(MouseEventArgs e) { base.OnMouseDown(e); if (e.Button == MouseButtons.Right && ExportAllData != null && !contextMenuStrip.Items.ContainsKey("導(dǎo)出全部")) { contextMenuStrip.Items.Add(new ToolStripMenuItem("導(dǎo)出全部", null, ExportAllData, "導(dǎo)出全部")); this.ContextMenuStrip = contextMenuStrip; } }
最后調(diào)用的時(shí)候就在ExportAllData事件中進(jìn)行導(dǎo)出即可。
實(shí)現(xiàn)效果
到此這篇關(guān)于C# Winform實(shí)現(xiàn)導(dǎo)出DataGridView當(dāng)前頁(yè)以及全部數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Winform導(dǎo)出DataGridView數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C# OpenCvSharp實(shí)現(xiàn)圖片批量改名
這篇文章主要為大家詳細(xì)介紹了C#如何結(jié)合OpenCvSharp實(shí)現(xiàn)圖片批量改名功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新聞效果的方法
這篇文章主要介紹了WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新聞效果的方法,涉及WinForm窗口滾動(dòng)字幕設(shè)置的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08C# 中的 IReadOnlyDictionary 和 IReadOnlyLis
C# 中的IReadOnlyDictionary和IReadOnlyList是接口,用于表示只讀的字典和只讀的列表,這些接口提供了對(duì)集合的只讀訪問權(quán)限,即不允許對(duì)集合進(jìn)行修改操作,這篇文章主要介紹了C# 中的 IReadOnlyDictionary 和 IReadOnlyList實(shí)例詳解,需要的朋友可以參考下2024-03-03C#使用whisper.net實(shí)現(xiàn)語(yǔ)音識(shí)別功能
這篇文章主要為大家詳細(xì)介紹了C#如何使用whisper.net實(shí)現(xiàn)語(yǔ)音識(shí)別功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以學(xué)習(xí)一下2023-11-11C#控件picturebox實(shí)現(xiàn)畫圖功能
這篇文章主要為大家詳細(xì)介紹了C#控件picturebox實(shí)現(xiàn)畫圖功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-09-09C#實(shí)現(xiàn)winform用子窗體刷新父窗體及子窗體改變父窗體控件值的方法
這篇文章主要介紹了C#實(shí)現(xiàn)winform用子窗體刷新父窗體及子窗體改變父窗體控件值的方法,涉及C#窗體交互的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07