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
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...