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
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...