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

C# Winform中DataGridView導出為Excel的實現(xiàn)示例

 更新時間:2022年05月09日 15:10:37   作者:嵌入式悅翔園  
本文主要介紹了C# Winform中DataGridView導出為Excel的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

1、前言

話不多說,跟著我的步驟保證你也能成功,下面直接開始!

2、效果展示

導出前

在這里插入圖片描述

導出后

在這里插入圖片描述

3、詳細步驟

下面是詳細操作步驟,請跟著我的步伐,一步一步進行操作,保證你能夠導出成功!

3.1 添加NPOI和NPOI.Excel包

首先請請確定你的vs已經(jīng)打開了【解決方案資源管理器】,打開步驟見下圖:

在這里插入圖片描述

在資源管理器中找到【引用】,然后在【引用】上右鍵選擇【管理程序包】并點擊,如下圖:

在這里插入圖片描述

在新打開的窗口中點擊【瀏覽】并在搜索框中依次輸入NPOI和NPOI.Excel并進行安裝,安裝按鈕位置如下圖:

在這里插入圖片描述

待安裝完成再進行下一步

3.2 創(chuàng)建NPOIHelper類

首先在資源管理器中選中你的項目,【右鍵】找到【添加】–>【類】,具體如下圖:

在這里插入圖片描述

創(chuàng)建一個名字為【NPOIHelper.cs】的類并打開

3.2.1 導入命名空間

復制下面的代碼,覆蓋你自動生成的命名空間

using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

3.2.2 插入代碼

將下面的代碼導入到下圖位置:

在這里插入圖片描述

public class ExcelUtility
        {
            /// <summary>
            /// 將excel導入到datatable
            /// </summary>
            /// <param name="filePath">excel路徑</param>
            /// <param name="isColumnName">第一行是否是列名</param>
            /// <returns>返回datatable</returns>
            public static DataTable ExcelToDataTable(string filePath, bool isColumnName)
            {
                DataTable dataTable = null;
                FileStream fs = null;
                DataColumn column = null;
                DataRow dataRow = null;
                IWorkbook workbook = null;
                ISheet sheet = null;
                IRow row = null;
                ICell cell = null;
                int startRow = 0;
                try
                {
                    using (fs = File.OpenRead(filePath))
                    {
                        // 版本后綴控制
                        if (filePath.IndexOf(".xlsx") > 0)
                            workbook = new XSSFWorkbook(fs);
                        // 版本后綴控制
                        else if (filePath.IndexOf(".xls") > 0)
                            workbook = new HSSFWorkbook(fs);

                        if (workbook != null)
                        {
                            sheet = workbook.GetSheetAt(0);//讀取第一個sheet,當然也可以循環(huán)讀取每個sheet
                            dataTable = new DataTable();
                            if (sheet != null)
                            {
                                int rowCount = sheet.LastRowNum;//總行數(shù)
                                if (rowCount > 0)
                                {
                                    IRow firstRow = sheet.GetRow(0);//第一行
                                    int cellCount = firstRow.LastCellNum;//列數(shù)

                                    //構建datatable的列
                                    if (isColumnName)
                                    {
                                        startRow = 1;//如果第一行是列名,則從第二行開始讀取
                                        for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
                                        {
                                            cell = firstRow.GetCell(i);
                                            if (cell != null)
                                            {
                                                if (cell.StringCellValue != null)
                                                {
                                                    column = new DataColumn(cell.StringCellValue);
                                                    dataTable.Columns.Add(column);
                                                }
                                            }
                                        }
                                    }
                                    else
                                    {
                                        for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
                                        {
                                            column = new DataColumn("column" + (i + 1));
                                            dataTable.Columns.Add(column);
                                        }
                                    }

                                    //填充行
                                    for (int i = startRow; i <= rowCount; ++i)
                                    {
                                        row = sheet.GetRow(i);
                                        if (row == null) continue;

                                        dataRow = dataTable.NewRow();
                                        for (int j = row.FirstCellNum; j < cellCount; ++j)
                                        {
                                            cell = row.GetCell(j);
                                            if (cell == null)
                                            {
                                                dataRow[j] = "";
                                            }
                                            else
                                            {
                                                //CellType(Unknown = -1,Numeric = 0,String = 1,Formula = 2,Blank = 3,Boolean = 4,Error = 5,)
                                                switch (cell.CellType)
                                                {
                                                    case CellType.Blank:
                                                        dataRow[j] = "";
                                                        break;
                                                    case CellType.Numeric:
                                                        short format = cell.CellStyle.DataFormat;
                                                        //對時間格式(2015.12.5、2015/12/5、2015-12-5等)的處理
                                                        if (format == 14 || format == 31 || format == 57 || format == 58)
                                                            dataRow[j] = cell.DateCellValue;
                                                        else
                                                            dataRow[j] = cell.NumericCellValue;
                                                        break;
                                                    case CellType.String:
                                                        dataRow[j] = cell.StringCellValue;
                                                        break;
                                                }
                                            }
                                        }
                                        dataTable.Rows.Add(dataRow);
                                    }
                                }
                            }
                        }
                    }
                    return dataTable;
                }
                catch (Exception)
                {
                    if (fs != null)
                    {
                        fs.Close();
                    }
                    return null;
                }
            }
        }
        public static bool DataTableToExcel(DataTable dt, string txtPath)
        {
            bool result = false;
            IWorkbook workbook = null;
            FileStream fs = null;
            IRow row = null;
            ISheet sheet = null;
            ICell cell = null;
            try
            {
                if (dt != null && dt.Rows.Count > 0)
                {
                    workbook = new HSSFWorkbook();
                    sheet = workbook.CreateSheet("Sheet0");//創(chuàng)建一個名稱為Sheet0的表
                    int rowCount = dt.Rows.Count;//行數(shù)
                    int columnCount = dt.Columns.Count;//列數(shù)

                    //設置列頭
                    row = sheet.CreateRow(0);//excel第一行設為列頭
                    for (int c = 0; c < columnCount; c++)
                    {
                        cell = row.CreateCell(c);
                        cell.SetCellValue(dt.Columns[c].ColumnName);
                    }

                    //設置每行每列的單元格,
                    for (int i = 0; i < rowCount; i++)
                    {
                        row = sheet.CreateRow(i + 1);
                        for (int j = 0; j < columnCount; j++)
                        {
                            cell = row.CreateCell(j);//excel第二行開始寫入數(shù)據(jù)
                            cell.SetCellValue(dt.Rows[i][j].ToString());
                        }
                    }
                    using (fs = File.OpenWrite(txtPath))
                    {
                        workbook.Write(fs);//向打開的這個xls文件中寫入數(shù)據(jù)
                        result = true;
                    }
                }
                MessageBox.Show("導出成功");
                return result;
            }
            catch (Exception)
            {
                if (fs != null)
                {
                    fs.Close();
                }
                return false;
            }

        }

3.3 給畫面添加SaveFileDialog

首先在工具箱里找到SaveFileDialog(如果不知到工具箱在哪的可以點擊上方的【視圖】–> 【工具箱】)

在這里插入圖片描述

點住SaveFileDialog拖入頁面中效果如上圖所示

3.4 引入命名空間

將下方命名空間引入到你按鈕所在的cs中(主要是3、4)

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.OleDb;

3.5 給按鈕添加click事件

給按鈕添加click事件(直接雙擊按鈕即可),并在click函數(shù)中插入以下代碼

//打開文件對話框,導出文件
SaveFileDialog saveFileDialog1 = new SaveFileDialog();
saveFileDialog1.Title = "保存文件";
saveFileDialog1.Filter = "Excel 文件(*.xls)|*.xls|Excel 文件(*.xlsx)|*.xlsx|所有文件(*.*)|*.*";
saveFileDialog1.FileName = "用戶信息.xls"; //設置默認另存為的名字
if (this.saveFileDialog1.ShowDialog() == DialogResult.OK)
{
    string txtPath = this.saveFileDialog1.FileName;
    string sql = "select ID as ID,UserName as 用戶名,LoginAccount as 賬號,UserPower as 用戶權限,Founder as 創(chuàng)建者,Addtime as 創(chuàng)建日期,Activestate as 狀態(tài) from UserData";
    SqlHelp sqlHelper = new SqlHelp();
    DataTable dt = sqlHelper.GetDataTableValue(sql);
    NPOIHelper.DataTableToExcel(dt, txtPath);
}

注意:上面的saveFileDialog1要和你視圖里的一樣一般沒問題,sql語句我就不詳細講了不會的可以看我其他文章。

4、 成功

相信大家根據(jù)我的步驟應該都能成功了,如果成功了別忘了三連哦!如果在操作過程中遇到什么問題記得評論或者私信。

5、寫在最后

到此這篇關于C# Winform中DataGridView導出為Excel的實現(xiàn)示例的文章就介紹到這了,更多相關C# Winform中DataGridView導出為Excel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C#計算程序執(zhí)行過程花費時間的方法

    C#計算程序執(zhí)行過程花費時間的方法

    這篇文章主要介紹了C#計算程序執(zhí)行過程花費時間的方法,涉及C#簡單的時間運算技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-09-09
  • C#獲得MAC地址(網(wǎng)卡序列號)的實現(xiàn)代碼

    C#獲得MAC地址(網(wǎng)卡序列號)的實現(xiàn)代碼

    這篇文章主要介紹了C#獲得MAC地址的實現(xiàn)代碼,需要的朋友可以參考下
    2014-02-02
  • C#獲取計算機硬件與操作系統(tǒng)的相關信息

    C#獲取計算機硬件與操作系統(tǒng)的相關信息

    這篇文章介紹了C#獲取計算機硬件與操作系統(tǒng)相關信息的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • C#表達式中的動態(tài)查詢詳解【譯】

    C#表達式中的動態(tài)查詢詳解【譯】

    這篇文章主要給大家介紹了關于C#表達式中動態(tài)查詢的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • C#使用PPT組件的CreateVideo方法實現(xiàn)視頻生成

    C#使用PPT組件的CreateVideo方法實現(xiàn)視頻生成

    這篇文章主要為大家詳細介紹了C#如何使用PPT組件的CreateVideo方法實現(xiàn)視頻生成,文中的示例代碼講解詳細,有需要的小伙伴可以跟隨小編一起學習一下
    2023-10-10
  • VS里使用C#制作窗口應用的項目實踐

    VS里使用C#制作窗口應用的項目實踐

    C#窗體的頻率使用特別高,本文主要介紹了VS里使用C#制作窗口應用的項目實踐,具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • c#語言入門類型和成員

    c#語言入門類型和成員

    這篇文章主要介紹了c#語言入門類型和成員,類 是最基本的 C# 類型。 類是一種數(shù)據(jù)結構,可在一個單元中就將狀態(tài)和操作結合起來。 類為類實例提供了定義。類支持繼承和多形性,即派生類 以擴展和專門針對基類的機制,下面來看看文章的詳細介紹
    2021-12-12
  • C#導入導出Excel數(shù)據(jù)的兩種方法

    C#導入導出Excel數(shù)據(jù)的兩種方法

    這篇文章主要為大家詳細介紹了C#導入導出Excel數(shù)據(jù)的兩種方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • c#繼承與多態(tài)使用示例

    c#繼承與多態(tài)使用示例

    繼承是面向對象程序設計的主要特征之一,允許重用現(xiàn)有類去創(chuàng)建新類的過程。下面使用示例學習一下c#繼承與多態(tài)
    2014-01-01
  • C#開啟線程的四種示例

    C#開啟線程的四種示例

    這篇文章主要介紹了C#開啟線程的四種方法,幫助大家更好的理解和使用c#,感興趣的朋友可以了解下
    2020-10-10

最新評論