欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# Winform實(shí)現(xiàn)導(dǎo)出DataGridView當(dāng)前頁(yè)以及全部數(shù)據(jù)

 更新時(shí)間:2023年07月18日 10:46:29   作者:Csharp 小記  
基本上,所有的業(yè)務(wù)系統(tǒng)都會(huì)要求有導(dǎo)出的功能,所以這篇文章主要為大家介紹了如何利用Winform實(shí)現(xiàn)原生DataGridView的導(dǎo)出功能,需要的可以參考一下

前言

基本上,所有的業(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#淺克隆與深克隆

    一文弄懂C#淺克隆與深克隆

    在C#中,淺克隆和深克隆是兩種常見的對(duì)象克隆技術(shù),本文主要介紹了C#淺克隆與深克隆,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-02-02
  • 利用C#守護(hù)Python進(jìn)程的方法

    利用C#守護(hù)Python進(jìn)程的方法

    這篇文章主要給大家介紹了關(guān)于如何利用C#守護(hù)Python進(jìn)程的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • C# OpenCvSharp實(shí)現(xiàn)圖片批量改名

    C# OpenCvSharp實(shí)現(xiàn)圖片批量改名

    這篇文章主要為大家詳細(xì)介紹了C#如何結(jié)合OpenCvSharp實(shí)現(xiàn)圖片批量改名功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-03-03
  • WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新聞效果的方法

    WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新聞效果的方法

    這篇文章主要介紹了WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新聞效果的方法,涉及WinForm窗口滾動(dòng)字幕設(shè)置的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08
  • C# 中的 IReadOnlyDictionary 和 IReadOnlyList實(shí)例詳解

    C# 中的 IReadOnlyDictionary 和 IReadOnlyLis

    C# 中的IReadOnlyDictionary和IReadOnlyList是接口,用于表示只讀的字典和只讀的列表,這些接口提供了對(duì)集合的只讀訪問權(quán)限,即不允許對(duì)集合進(jìn)行修改操作,這篇文章主要介紹了C# 中的 IReadOnlyDictionary 和 IReadOnlyList實(shí)例詳解,需要的朋友可以參考下
    2024-03-03
  • C#使用whisper.net實(shí)現(xiàn)語(yǔ)音識(shí)別功能

    C#使用whisper.net實(shí)現(xiàn)語(yǔ)音識(shí)別功能

    這篇文章主要為大家詳細(xì)介紹了C#如何使用whisper.net實(shí)現(xiàn)語(yǔ)音識(shí)別功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以學(xué)習(xí)一下
    2023-11-11
  • C#控件picturebox實(shí)現(xiàn)畫圖功能

    C#控件picturebox實(shí)現(xiàn)畫圖功能

    這篇文章主要為大家詳細(xì)介紹了C#控件picturebox實(shí)現(xiàn)畫圖功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • C#實(shí)現(xiàn)winform用子窗體刷新父窗體及子窗體改變父窗體控件值的方法

    C#實(shí)現(xiàn)winform用子窗體刷新父窗體及子窗體改變父窗體控件值的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)winform用子窗體刷新父窗體及子窗體改變父窗體控件值的方法,涉及C#窗體交互的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • C# List的賦值問題的解決

    C# List的賦值問題的解決

    本文主要介紹了C# List的賦值問題的解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • C#實(shí)現(xiàn)Ping的方法小結(jié)

    C#實(shí)現(xiàn)Ping的方法小結(jié)

    這篇文章主要介紹了C#實(shí)現(xiàn)Ping的方法,以兩個(gè)實(shí)例形式形式較為詳細(xì)的分析了C#實(shí)現(xiàn)ping功能的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08

最新評(píng)論