使用.Net C#開發批量ACCESS資料庫壓縮軟體

來源:互聯網
上載者:User
第一次寫使用.NET C# 開發了一個稍稍像樣子的軟體,在這個軟體開發過程中我查了好多資料,也學到了很多小技巧

像FolderBrowserDialog(用於瀏覽選擇檔案夾的對話方塊)、MessageBox(訊息處理對話方塊)、DirectoryInfo(目錄資訊,可用於建立、檢測是否存在等對目錄的操作)、FileInfo(檔案資訊,可用於檔案的檢測、檔案資訊的擷取、複製等操作)、DataGridView(資料表格控制項,用於顯示檔案資訊列表資料)、DataRowView(對一些資料來源資訊進行篩選,排序)、System.Diagnostics.Process.Start(啟動其它程式開啟檔案夾目錄),下面就依次介紹一下在此軟體開發中我都使用到以上控制項、對象的哪些內容。

  一、FolderBrowserDialog(檔案夾瀏覽對話方塊),在此軟體中用於開啟選擇資料庫根目錄或開啟建立、選擇備份目錄,下面是兩處位置的代碼詳細介紹。

   1.選擇資料庫目錄,在此處不需要建立檔案夾,因此屏蔽建立檔案夾按鈕。
 

C#代碼
  1.          FolderBrowserDialog df = new FolderBrowserDialog();   
  2.   
  3.    //設定檔案瀏覽對話方塊上的描述內容   
  4.           df.Description = "選擇所有資料庫檔案所在根目錄地址";   
  5.   
  6.    //不顯示對話方塊下方的建立新檔案夾按鈕   
  7.           df.ShowNewFolderButton = false;   
  8.   
  9.    /*  
  10. 判斷是否已直接輸入檔案夾目錄位址,如果存在則將此值賦於對話方塊的已選地址,這樣就可以讓對話方塊顯示您上次選擇或添加的目錄位址了。  
  11.    */  
  12.           if (tBoxDbRoot.Text != "")   
  13.           {   
  14.               df.SelectedPath = tBoxDbRoot.Text;   
  15.           }   
  16.           else  
  17.           {   
  18.               df.RootFolder = Environment.SpecialFolder.MyComputer;//指定對話方塊預設顯示的根目錄地址 注意RootFolder的接收資料類型   
  19.           }   
  20.    //顯示檔案夾對話方塊,並返回對話方塊處理結果數值   
  21.           DialogResult result = df.ShowDialog();   
  22.           if (result == DialogResult.OK) //另外一種判斷方法 if (df.ShowDialog(this) == DialogResult.OK)   
  23.           {   
  24. //將中的資料庫目錄地址賦於類全域變數資料庫根目錄   
  25.               string folderPath = df.SelectedPath;   
  26.               if (folderPath != "")   
  27.               {   
  28.                   tBoxDbRoot.Text = folderPath;   
  29.                   Cls_dbRootPath = tBoxDbRoot.Text;   
  30.               }   
  31.           }  

     2.選擇Database Backup目錄或建立新的Database Backup目錄

C#代碼
  1.               FolderBrowserDialog bakFolder = new FolderBrowserDialog();   
  2.               bakFolder.Description = "選擇所有資料庫檔案備份目錄";   
  3. //這裡沒有設計 bakFolder.ShowNewFolderButton是因為預設些按鈕是顯示的。   
  4.               if (Cls_dbBackRootPath != "")   
  5.               {   
  6.                   bakFolder.SelectedPath = Cls_dbBackRootPath;   
  7.               }   
  8.               else  
  9.               {   
  10.                   bakFolder.RootFolder = Environment.SpecialFolder.MyComputer;   
  11.               }   
  12.               if (bakFolder.ShowDialog(this) == DialogResult.OK)   
  13.               {   
  14.                   Cls_dbBackRootPath = bakFolder.SelectedPath;   
  15.     //這裡省略了開始處理執行Database Backup的代碼...   
  16. }  

    二、MessageBox(訊息對話方塊)其實他也沒有什麼好介紹的,只使用到了它的訊息狀態返回執行其它代碼和普通的訊息提示顯示。

 1.具有訊息結果返回的處理代碼

C#代碼
  1. DialogResult resultNum=MessageBox.Show("資料庫檔案已備份到“" + Cls_dbBackRootPath + "”,是否開啟備份目錄?", "Database Backup成功", MessageBoxButtons.YesNo, MessageBoxIcon.Information);   
  2. if (resultNum == DialogResult.Yes)//判斷是否按下“是”的按鈕   
  3. {   
  4.   openDirectoryAddress(Cls_dbBackRootPath);    
  5. }  

 這裡就不需要再做介紹了,看一下訊息對話方塊的幾個參數都分別是什麼

 2.以不同姿態顯示的訊息對話方塊

C#代碼
  1. MessageBox.Show("這裡是訊息的提示內容", "訊息的提示標題",訊息對話方塊上顯示的按鈕, 訊息對話方塊上顯示的提示表徵圖);  

    三、DirectoryInfo(目錄資訊)檢測目錄是否存在、建立目錄檔案夾在軟體中主要用於分析並建立指定的檔案地址字串中各級目錄

 1.檢測目錄是否存在使用Exists方法

C#代碼
  1. DirectoryInfo curFolderRoot = new DirectoryInfo(Cls_dbRootPath);//指定需要檢測的檔案夾物理地址   
  2. if (curFolderRoot.Exists)   
  3.               {   
  4. //...   
  5. }   

 2.建立目錄使用Create()方法

C#代碼
  1. DirectoryInfo curFolderRoot = new DirectoryInfo(Cls_dbRootPath);//指定需要檢測的檔案夾物理地址   
  2. if (curFolderRoot.Exists)   
  3.               {   
  4.     curFolderRoot.Create()   
  5. }  

    四、FileInfo(檔案資訊) 擷取檔案資訊、複製、刪除檔案等,將指定檔案夾下的合格檔案的相關資訊依次寫入DataGridView控制項。

 1.擷取檔案資訊代碼:

C#代碼
  1. FileInfo dbFile = new FileInfo(dbPath);   
  2.   
  3. 寫入DataGridView控制項的某行某列上   
  4. dGrideFileList.Rows[rowsNum].Cells[1].Value = dbFile.Length;   
  5.   
  6. 修改時間寫入   
  7. dGrideFileList.Rows[rowsNum].Cells[5].Value = dbFile.LastWriteTime.ToString();  

  2.檢測檔案是否存在執行刪除複製操作

C#代碼
  1.      FileInfo copyFile = new FileInfo(copyToPath);   
  2. 檢測檔案是否存在   
  3.      if (copyFile.Exists)   
  4.      {   
  5. //如果存在檔案則執行刪除操作   
  6.        File.Delete(copyToPath);   
  7.      }   
  8. 執行檔案的複製操作   
  9.      File.Copy(dbPath, copyToPath); 

   五、DataGridView(資料表格控制項)用於顯示、更新、刪除等對資料列表的操作

 1.將遍曆符合要求的資料添加到控制項

C#代碼
  1.         filesTotelSize += curDbFile.Length;   
  2.   
  3.  //將檔案資訊寫入字串數組   
  4.         string[] fileInfoArr = new string[]{   
  5.             curDbFile.FullName.Replace(Cls_dbRootPath,"").ToString(),   
  6.              CheckFile.FormatSize(curDbFile.Length),   
  7.              "0",   
  8.              "未壓縮",   
  9.              CheckFile.GetTypeName(filePath),   
  10.              curDbFile.LastWriteTime.ToString()   
  11.         };   
  12.   
  13. //將檔案行數組資料添加至控制項行集中   
  14. dGrideFileList.Rows.Add(fileInfoArr);   
  15.   
  16. //重新整理控制項顯示   
  17. dGrideFileList.Refresh();  

2.讓控制項垂直捲軸自動滾動

C#代碼
  1. dGrideFileList.FirstDisplayedScrollingRowIndex = i;   
  2. dGrideFileList.Refresh();  

3.游標定位跟隨遍曆定位到控制項儲存格

C#代碼
  1. dGrideFileList.CurrentCell=dGrideFileList.Rows[i].Cells[0];   
  2. dGrideFileList.Refresh();  

4.DataRowView刪除控制項選中行

 C#代碼

  1. //刪除選中行資料   
  2. if (this.dGrideFileList.SelectedRows.Count > 0)   
  3. {   
  4.     DataRowView drv = dGrideFileList.SelectedRows[0].DataBoundItem as DataRowView;   
  5.     drv.Delete();   
  6. }  

    六、Process啟動Exporler.exe開啟指定物理地址檔案夾

C#代碼
  1. #region 開啟目錄位址   
  2. /// <summary>   
  3. /// 開啟目錄位址   
  4. /// </summary>   
  5. /// <param name="dirAddress">需要開啟的檔案夾目錄物理地址</param>   
  6. private void openDirectoryAddress(string dirAddress)   
  7. {   
  8.     DirectoryInfo dirFolder = new DirectoryInfo(dirAddress);   
  9.     if (dirFolder.Exists)   
  10.     {   
  11.         System.Diagnostics.Process.Start("explorer.exe", dirAddress);   
  12.     }   
  13.     else  
  14.     {   
  15.         MessageBox.Show("未找到需要開啟的目錄位址", "錯誤提示", MessageBoxButtons.OK, MessageBoxIcon.Error);   
  16.     }   
  17. }  
  18. #endregion  


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.