C# 使用dataGridView導入導出excel(NPOI),可以通過關鍵字定位,刪除空行等功能

来源:https://www.cnblogs.com/qi-jiayou/archive/2022/06/17/16385092.html
-Advertisement-
Play Games

做下記錄, 首先插入一個dataGridView控制項,兩個button按鈕(導入數據,導出數據),一個ComboBox(獲取列標題使用),一個textbox(輸入關鍵字),一個定位按鈕(定位使用) 1,導入數據(NPOI) 1 2 private void daoRuShuJu_cmd_Click( ...


做下記錄,

首先插入一個dataGridView控制項,兩個button按鈕(導入數據,導出數據),一個ComboBox(獲取列標題使用),一個textbox(輸入關鍵字),一個定位按鈕(定位使用)

1,導入數據(NPOI)

 1   
 2         private void daoRuShuJu_cmd_Click(object sender, EventArgs e)
 3         {
 4             DataTable daNpoi = new DataTable();
 5             string fileName = Application.StartupPath;
 6             fileName += "\\4G模組表.xls";  
 7             string sheetName = "4G模組情況表";
 8             bool isColumnName = true;
 9             IWorkbook workbook;
10             string fileExt = Path.GetExtension(fileName).ToString();
11             using (FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read))
12             {
13                 if (fileExt == ".xlsx")
14                 {
15                     workbook = new XSSFWorkbook(fs);
16                 }
17                 else if (fileExt == ".xls")
18                 {
19                     workbook = new HSSFWorkbook(fs);
20                 }
21                 else
22                 {
23 
24                     workbook = null;
25                 }
26 
27                 ISheet sheet = null;
28                 if (sheetName != null && sheetName != "")
29                 {
30                     sheet = workbook.GetSheet(sheetName);
31                     if (sheet == null)
32                     {
33                         sheet = workbook.GetSheetAt(0);
34                     }
35 
36                 }
37                 else
38                 {
39                     sheet = workbook.GetSheetAt(0);
40                 }
41 
42                 IRow header = sheet.GetRow(sheet.FirstRowNum);
43                 int startRow = 0;
44                 if (isColumnName)
45                 {
46                     startRow = sheet.FirstRowNum + 1;
47                     for (int i = header.FirstCellNum; i < header.LastCellNum; i++)
48                     {
49                         ICell cell = header.GetCell(i);
50                         if (cell != null)
51                         {
52                             string cellValue = cell.ToString();
53                             if (cellValue != null)
54                             {
55                                 DataColumn col = new DataColumn(cellValue);
56                                 daNpoi.Columns.Add(col);
57                             }
58                             else
59                             {
60                                 DataColumn col = new DataColumn();
61                                 daNpoi.Columns.Add(col);
62                             }
63                         }
64                     }
65                 }
66 
67                 for (int i = startRow; i <= sheet.LastRowNum; i++)
68                 {
69                     IRow row = sheet.GetRow(i);
70                     if (row == null)
71                     {
72                         continue;
73                     }
74                     DataRow dr = daNpoi.NewRow();
75                     for (int j = row.FirstCellNum; j < row.LastCellNum; j++)
76                     {
77 
78                         if (row.GetCell(j) != null)
79                         {
80                             dr[j] = row.GetCell(j).ToString();
81                         }
82                     }
83                     daNpoi.Rows.Add(dr);
84                 }
85             }
86 
87             dataGridView1.DataSource = daNpoi;
88         }

2,導出數據(NPOI)

 1   private void baoCunShuJu_cmd_Click(object sender, EventArgs e)
 2         {
 3             DataTable dtTable = dataGridView1.DataSource as DataTable;
 4             string sheetName = "4G模組情況表";   //sheet名字
 5             IWorkbook wb = new HSSFWorkbook();
 6             ISheet sheet = string.IsNullOrEmpty(sheetName) ? wb.CreateSheet("sheet1") : wb.CreateSheet(sheetName);
 7             int rowIndex = 0;
 8             if (dtTable.Columns.Count > 0)
 9             {
10                 IRow header = sheet.CreateRow(rowIndex);
11                 for (int i = 0; i < dtTable.Columns.Count; i++)
12                 {
13                     ICell cell = header.CreateCell(i);
14                     cell.SetCellValue(dtTable.Columns[i].ColumnName);
15                 }
16             }
17             if (dtTable.Rows.Count > 0)
18             {
19                 for (int i = 0; i < dtTable.Rows.Count; i++)
20                 {
21                     rowIndex++;
22                     IRow row = sheet.CreateRow(rowIndex);
23                     for (int j = 0; j < dtTable.Columns.Count; j++)
24                     {
25                         ICell cell = row.CreateCell(j);
26                         cell.SetCellValue(dtTable.Rows[i][j].ToString());
27                     }
28                 }
29             }
30 
31             for (int i = 0; i < dtTable.Columns.Count; i++)
32             {
33                 sheet.AutoSizeColumn(i);
34             }
35 
36             string fileName = Application.StartupPath;      // debug 目錄                     
37             fileName += "\\4G模組表.xls";  //excel 名字
38             using (FileStream fs = new FileStream(fileName, FileMode.Create, FileAccess.Write))
39             {
40                 wb.Write(fs);
41             }
42             MessageBox.Show("保存成功");
43         }

3,刪除空行函數

// 刪除空白行調用函數,在不需要用戶添加新行或者數據的時候使用,ALLowUsertoAddRows 這個屬性需要設置false
//如果ALLowUsertoAddRows 這個屬性是true,則,用戶可以輸入數據,但是row < view.Rows.Count需要 -1不去判斷最後一行

// 所以傳入的x根據情況更改,想用戶可以輸入,ALLowUsertoAddRows的值為true,    x=0;

//不想用戶輸入ALLowUsertoAddRows的值為false    x=1;

 1  private void clearGrid(DataGridView view, int x)
 2         {
 3             for (int row = 0; row < (view.Rows.Count - x); ++row)
 4             {
 5                 bool isEmpty = true;
 6                 for (int col = 0; col < view.Columns.Count; ++col)
 7                 {
 8                     object value = view.Rows[row].Cells[col].Value;
 9                     if (value != null && value.ToString().Length > 0)
10                     {
11                         isEmpty = false;
12                         break;
13                     }
14                 }
15                 if (isEmpty)
16                 {
17                     view.Rows.RemoveAt(row--);
18                 }
19             }
20         }

4,獲取excel的列標題,給ComboBox控制項

 1  public void huoQu_Column()   //把excel表各列標題弄到combobox上
 2         {
 3            // int Rowcount = dataGridView1.RowCount;//獲取datagridview的行數
 4             int Columncount = dataGridView1.ColumnCount;//獲取datagridview的列數
 5            // dataGridView2.ColumnCount = Columncount;  //新增列
 6            // dataGridView2.ColumnHeadersVisible = true;  //新增的列顯示出來
 7             for (int i = 0; i < Columncount; i++)
 8             {
 9                 string var = this.dataGridView1.Columns[i].HeaderText;
10                // this.dataGridView2.Columns[i].HeaderText = this.dataGridView1.Columns[i].HeaderText;  //2的列名和1的一樣
11               //  dataGridView2.Columns[i].MinimumWidth = dataGridView1.Columns[i].MinimumWidth;   //2的列寬和1 一樣
12                 // = dataGridView1.Rows[0].Cells[i].Value.ToString();
13                 lie_ming_cb.Items.Add(var);
14               //  lie_ming_cb_1.Items.Add(var);
15                // if (var == "IMEI")
16                // {
17                    // lie_ming_cb_1.SelectedIndex = i;
18               //  }
19             }
20             lie_ming_cb.SelectedIndex = 0;
21         }

 

5,定位,可以在每個列里根據關鍵字去查找,並且定位到行,可實現下一條功能

 1  int xiayitiao_int = 0;  //下一條標記
 2 
 3         private void chaZhao_bt_1_Click(object sender, EventArgs e)   //定位按鈕
 4         {
 5             DataTable rentTable = (DataTable)dataGridView1.DataSource;//獲取數據源
 6             int r = 0;
 7             bool dingwei_f;  //定位標記,
 8 
 9 
10             if ((guanJianZi_box.Text != "") && (guanJianZi_box.Text != "/請輸入關鍵字/"))
11             {
12                 for (int i = xiayitiao_int; i < rentTable.Rows.Count; i++)
13                 {
14                     dingwei_f = rentTable.Rows[i][lie_ming_cb.Text].ToString().Contains(guanJianZi_box.Text); //對比字元串,
15 
16                     if (dingwei_f)
17                     {
18                         //指定行
19                         dataGridView1.ClearSelection();
20                         dataGridView1.Rows[i].Selected = true;
21                         //讓指定行處於選中狀態(狀態)
22                         dataGridView1.CurrentCell = dataGridView1.Rows[i].Cells[1];
23                         dataGridView1.CurrentRow.Selected = true;
24                         dingwei_f = false;
25                         xiayitiao_int = i+1; //下一條的標記
26                         r++;
27                         return;
28                     }
29                 }
30                 if (r > 0)
31                 {
32 
33                 }
34                 else
35                 {
36                     MessageBox.Show("沒有匹配項或已經是最後一條,將從第一條繼續查找", "提示");
37                     xiayitiao_int = 0;   //重新查找
38                 }
39             }
40             else
41             {
42                 MessageBox.Show("請輸入正確的關鍵字", "提示");
43             }
44         }

6,textbox可以敲回車直接查找,需要添加textbox的KeyDown事件

 private void guanJianZi_box_KeyDown(object sender, KeyEventArgs e)
        {
            if (e.KeyValue == 13)
            {
                chaZhao_bt_1_Click(sender, e);
            }
        }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前幾天看了一篇文章,自己動手試了下,發現有些不一樣結論,作博客記錄下,本文主要研究兩個問題: 包裝流的close方法是否會自動關閉被包裝的流? 關閉流方法是否有順序? 包裝流的close方法是否會自動關閉被包裝的流? 平時我們使用輸入流和輸出流一般都會使用buffer包裝一下,直接看下麵代碼(這個代 ...
  • 能夠基於Java Agent編寫出普通類的代理 理解Byte Buddy的作用 能夠基於Byte Buddy編寫動態代理 1 Byte Buddy Byte Buddy 是一個代碼生成和操作庫,用於在 Java 應用程式運行時創建和修改 Java 類,而無需編譯器的幫助。除了 Java 類庫附帶的代 ...
  • 面對對象程式設計 第十到十六周作業總結 引言:java的課程進入尾聲,但是編程的路才剛開始。 前言:這三周的大作業主要考察各個類之間的關係,數據的封裝,類的繼承,多態,介面,抽象類,集合框架等多個知識的綜合運用。 自學正則表達式的使用,有些題目對於格式的判斷非常的複雜,使用正則表達有效判斷了輸入的合 ...
  • pycharm 常用快捷鍵 更多教程請點擊查看gale博客🚀 最重要的快捷鍵 ctrl+shift+A:萬能命令行 shift兩次:查看資源文件 新建工程第一步操作 module設置把空包分層去掉,compact empty middle package 設置當前的工程是utf-8,設置的Edit ...
  • 背景 我在的學校校園網登錄是web式的,即隨便打開一個網頁就會自動跳轉到登錄頁面,然後輸入用戶名密碼,點登錄,便可以上網了。 但這種登錄方式有個缺點:登錄狀態不會一直保持下去。即過一段時間就會掉線,然後你需要重新登陸才行。這個時間大概是一天。 這就蛋疼了,想讓實驗室的電腦隨時保持聯網狀態怎麼辦呢?( ...
  • 今天分享一篇文章,是關於如何使用 Manim 這個工具 Python 工具庫來製作視頻的。 據我所知,目前應該是沒有專門的書籍和教程來介紹這個工具的。至於教程,不同版本的Manim有一部分文檔,其中 Manim社區 版的文檔相對而言要完善些。 本次僅介紹 Manim 中 文本 的使用,使用的版本為 ...
  • 程式員都知道寫代碼是一件低調又枯燥的事情,一天到晚盯著電腦屏幕看。怎麼能讓寫代碼變成一件酷炫的事情,那就從裝扮編輯器開始。 安裝了這些插件,保證同事看到後,都會問你。 兄弟,你安裝了什麼插件,讓我也裝一下。 1. 先換個漂亮主題 Vuesion Theme Idea編輯器的界麵灰矇矇的,有點性冷淡的 ...
  • 一、題目 描述 給定一個僅包含0和1的n*n二維矩陣,請計算二維矩陣的最大值。 計算規則如下 1、每行元素按下標順序組成一個二進位數(下標越大約排在低位),二進位數的值就是該行的值,矩陣各行之和為矩陣的值 2、允許通過向左或向右整體迴圈移動每個元素來改變元素在行中的位置 比如:[1,0,1,1,1] ...
一周排行
    -Advertisement-
    Play Games
  • 周末,寫點簡單的水一下。 新版本的vs創建項目的時候可以選擇自帶一個swagger。然而這隻是基本的swagger功能。 幾個介面無所謂啦,隨著介面越來越多,就這麼丟給你,一時間也會懵逼,所以這篇文章要做的有兩個功能。 給swagger文檔添加註釋 給swagger添加切換“版本”的功能(也可以理解 ...
  • 大家好,我是沙漠盡頭的狼。 本文首發於Dotnet9,介紹使用Lib.Harmony庫攔截第三方.NET庫方法,達到不修改其源碼並能實現修改方法邏輯、預期行為的效果,並且不限於只攔截public訪問修飾的類及方法,行文目錄: 什麼是方法攔截? 示常式序攔截 非public方法怎麼攔截? 總結 1. ...
  • 問題代碼: xmal:一個按鈕+一個顯示框 1 <Button Width="100" Height="50" Margin="10" Click="Button_Click">test</Button> 2 <TextBox x:Name="display" Width="300" Height= ...
  • 前置條件 ​ 阿裡雲伺服器一臺(可在購買伺服器時勾選安裝寶塔選項,免去後面的寶塔安裝) ​ 設置阿裡雲伺服器密碼並登陸伺服器 ​ 以下操作均在伺服器Linux中進行(使用遠程連接工具登錄) 寶塔登錄 登錄阿裡雲伺服器在Linux命令行中輸入bt,查看寶塔信息 ​ 根據寶塔信息提供的網站登陸寶塔服務( ...
  • GetTokenInformation 用於檢索進程或線程的令牌(Token)信息。Token是一個數據結構,其包含有關進程或線程的安全上下文,代表當前用戶或服務的安全標識符和許可權信息。GetTokenInformation函數也可以用來獲取這些安全信息,通常用於在運行時檢查某個進程或線程的許可權或安... ...
  • matplotlib 在1.0版本之前其實是不支持3D圖形繪製的。 後來的版本中,matplotlib加入了3D圖形的支持,不僅僅是為了使數據的展示更加生動和有趣。更重要的是,由於多了一個維度,擴展了其展示數據分佈和關係的能力,可以一次從三個維度來比較數據。 下麵介紹在matplotlib中繪製各類 ...
  • 編寫一個App就能編譯發佈到iOS、Android和Web等各大平臺的跨平臺技術,各大廠商一直都有研究和發佈對應技術產品,目前最熱門的莫過於Flutter框架了。而Dart作為其唯一的編程語言,今天我們開始來體驗一下…… ...
  • 實現基本的線程池 前提:我們要實現的線程池有如下功能: 基本的線程池模型 能提交和運行任務 能正常關閉線程池 線程的拒絕策略 線程池擴容 縮容線程池 代碼地址: 1、線程池的介紹? 線程池是什麼? 線程池是一種利用池化技術來管理線程的一種技術。 當沒有線程池的時候,我們如何創建線程? 繼承Threa ...
  • SDRAM基本信息 儲存能力計算 4X16X4=256(Mbit),註意不是MByte SDRAM控制 sdram包含兩個部分:sdram_ctrl、fifo_ctrl。 sdram_ctrl:其頂層為SDRAM的控制模塊內部實例化了5個模塊,有初始化、自刷新、寫和讀模塊,還有一個仲裁模塊對這四個不 ...
  • 歡迎訪問我的GitHub 這裡分類和彙總了欣宸的全部原創(含配套源碼):https://github.com/zq2599/blog_demos 本篇概覽 欣宸正在為接下新的Java雲原生實戰系列原創做準備,既然是實戰,少不了一套雲原生環境,以下內容是必不可少的: linux操作系統 kuberne ...