Winform中實現批量文件複製(附代碼下載)

来源:https://www.cnblogs.com/badaoliumangqizhi/archive/2019/12/12/12029056.html
-Advertisement-
Play Games

場景 效果 將要批量複製的文件拖拽到窗體中,然後點擊下邊選擇目標文件夾,然後點擊複製按鈕。 註: 博客主頁: https://blog.csdn.net/badao_liumang_qizhi 關註公眾號 霸道的程式猿 獲取編程相關電子書、教程推送與免費下載。 實現 新建一個窗體,佈局設計如下 上面 ...


場景

效果

 

 

將要批量複製的文件拖拽到窗體中,然後點擊下邊選擇目標文件夾,然後點擊複製按鈕。

 

 

註:

博客主頁:
https://blog.csdn.net/badao_liumang_qizhi
關註公眾號
霸道的程式猿
獲取編程相關電子書、教程推送與免費下載。

實現

新建一個窗體,佈局設計如下

上面是一個ListView,下麵是TextBox和兩個Button,然後添加一個路徑選擇控制項。

 

 

在窗體的load事件中對ListView進行樣式設置

 private void Form1_Load(object sender, EventArgs e)
        {
            listView1.GridLines = true;//在各數據之間形成網格線
            listView1.View = View.Details;//顯示列名稱
            listView1.FullRowSelect = true;//在單擊某項時,對其進行選中
            listView1.HeaderStyle = ColumnHeaderStyle.Nonclickable;//隱藏列標題
            listView1.Columns.Add("文件路徑", listView1.Width - 5, HorizontalAlignment.Right);
        }

 

然後編寫listView的脫拽事件,使其能獲取到拖拽文件並顯示

private void listView1_DragEnter(object sender, DragEventArgs e)
        {
            e.Effect = DragDropEffects.Copy;       //設置拖放操作中目標放置類型為複製
            String[] str_Drop = (String[])e.Data.GetData(DataFormats.FileDrop, true);//檢索數據格式相關聯的數據
            Data_List(listView1, str_Drop[0]);
        }
  public void Data_List(ListView LV, string F)  //Form或MouseEventArgs添加命名空間using System.Windows.Forms;
        {
            ListViewItem item = new ListViewItem(F);
            LV.Items.Add(item);
        }

 

然後編寫三個點按鈕的點擊事件,使其打開路徑選擇對話框,並將選擇的路徑顯示在TextBox中。

private void button2_Click(object sender, EventArgs e)
        {
            if (folderBrowserDialog1.ShowDialog() == DialogResult.OK)
            {
                textBox1.Text = folderBrowserDialog1.SelectedPath;
            }
        }

 

然後編寫複製按鈕的點擊事件

private void button1_Click(object sender, EventArgs e)
        {
            string FileName = "";
            int tem_n = 0;
            string DName = "";
            if (textBox1.Text.Length > 0 && listView1.Items.Count > 0)
            {
                try
                {
                    for (int i = 0; i < listView1.Items.Count; i++)
                    {
                        FileName = listView1.Items[i].SubItems[0].Text;
                        tem_n = FileName.LastIndexOf("\\");
                        FileName = FileName.Substring(tem_n + 1, FileName.Length - tem_n - 1);
                        DName = textBox1.Text.Trim() + "\\" + FileName;
                        CopyFile(listView1.Items[i].SubItems[0].Text, DName, 1024);
                        this.Text = "複製:" + listView1.Items[i].SubItems[0].Text;
                    }
                    MessageBox.Show("文件批量複製完成。");
                }
                catch
                {
                    MessageBox.Show("文件複製錯誤。");
                }
            }
        }

 

在複製按鈕的點擊事件中執行複製文件的方法CopyFile

FileStream FormerOpen;
        FileStream ToFileOpen;
        /// <summary>
        /// 文件的複製
        /// </summary>
        /// <param FormerFile="string">源文件路徑</param>
        /// <param toFile="string">目的文件路徑</param> 
        /// <param SectSize="int">傳輸大小</param> 
        /// <param progressBar="ProgressBar">ProgressBar控制項</param> 
        public void CopyFile(string FormerFile, string toFile, int SectSize)
        {
            FileStream fileToCreate = new FileStream(toFile, FileMode.Create);  //創建目的文件,如果已存在將被覆蓋
            fileToCreate.Close();          //關閉所有資源
            fileToCreate.Dispose();          //釋放所有資源
            FormerOpen = new FileStream(FormerFile, FileMode.Open, FileAccess.Read);//以只讀方式打開源文件
            ToFileOpen = new FileStream(toFile, FileMode.Append, FileAccess.Write); //以寫方式打開目的文件
            //根據一次傳輸的大小,計算傳輸的個數
            //int max = Convert.ToInt32(Math.Ceiling((double)FormerOpen.Length / (double)SectSize));

            int FileSize;            //要拷貝的文件的大小
            //如果分段拷貝,即每次拷貝內容小於文件總長度
            if (SectSize < FormerOpen.Length)
            {
                byte[] buffer = new byte[SectSize];       //根據傳輸的大小,定義一個位元組數組
                int copied = 0;          //記錄傳輸的大小
                while (copied <= ((int)FormerOpen.Length - SectSize))   //拷貝主體部分
                {
                    FileSize = FormerOpen.Read(buffer, 0, SectSize);   //從0開始讀,每次最大讀SectSize
                    FormerOpen.Flush();        //清空緩存
                    ToFileOpen.Write(buffer, 0, SectSize);     //向目的文件寫入位元組
                    ToFileOpen.Flush();         //清空緩存
                    ToFileOpen.Position = FormerOpen.Position;    //使源文件和目的文件流的位置相同
                    copied += FileSize;         //記錄已拷貝的大小
                }
                int left = (int)FormerOpen.Length - copied;      //獲取剩餘大小
                FileSize = FormerOpen.Read(buffer, 0, left);     //讀取剩餘的位元組
                FormerOpen.Flush();         //清空緩存
                ToFileOpen.Write(buffer, 0, left);       //寫入剩餘的部分
                ToFileOpen.Flush();         //清空緩存
            }
            //如果整體拷貝,即每次拷貝內容大於文件總長度
            else
            {
                byte[] buffer = new byte[FormerOpen.Length];    //獲取文件的大小
                FormerOpen.Read(buffer, 0, (int)FormerOpen.Length);   //讀取源文件的位元組
                FormerOpen.Flush();         //清空緩存
                ToFileOpen.Write(buffer, 0, (int)FormerOpen.Length);   //寫放位元組
                ToFileOpen.Flush();         //清空緩存
            }
            FormerOpen.Close();          //釋放所有資源
            ToFileOpen.Close();          //釋放所有資源
        }

 

代碼下載

https://download.csdn.net/download/BADAO_LIUMANG_QIZHI/12028246


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

-Advertisement-
Play Games
更多相關文章
  • 內網穿透 有時候,我們在外想要訪問家裡主機的資料,要麼由於主機處於家庭路由器下,是非公網IP,要麼就是運營商隨機分配的一個公網IP,都很難直接連上主機獲取資料。那麼,有什麼辦法可以解決這一難題?答案就是 內網穿透。 內網穿透,又叫NAT(Network Address Translation)穿透, ...
  • HTTP狀態碼 HTTP狀態碼會告訴API的消費者以下事情: 請求是否執行成功了 如果請求失敗了,那麼誰為它負責 HTTP的狀態碼有很多,但是Web API不一定需要支持所有的狀態碼。HTTP狀態碼一共分為5個級別: 1xx,屬於信息性的狀態碼。Web API並不使用1xx的狀態碼。 2xx,意味著 ...
  • 通過一個小組件,熟悉 Blazor 服務端組件開發。 "github" 一、環境搭建 vs2019 16.4, asp.net core 3.1 新建 Blazor 應用,選擇 asp.net core 3.1。 根文件夾下新增目錄 Components,放置代碼。 二、組件需求定義 Compone ...
  • 今天在學.net core的時候發現了一個問題,終結點死活映射不了自己添加的控制器,後經過研究發現解決方法,可能這個問題不應該叫做問題,可是我是初學者,就把這個問題給拎出來。本人開發環境 VS2019+.Net Core 3.1,問題重現過程: 1.新建Web Core項目,選擇空項目 2.新建文件 ...
  • static byte[] GetBytesFromDic(Dictionary<string,string> dic) { if(dic==null || !dic.Any()) { return null; } using (MemoryStream ms = new MemoryStream( ...
  • 場景 效果 點擊剪切按鈕 點擊粘貼按鈕 註: 博客主頁: https://blog.csdn.net/badao_liumang_qizhi 關註公眾號 霸道的程式猿 獲取編程相關電子書、教程推送與免費下載。 實現 新建一個form窗體,設計佈局如下 主要是有兩個PictureBox控制項以及四個按鈕 ...
  • 1 using System; 2 using System.Collections.Generic; 3 using System.ComponentModel; 4 using System.Data; 5 using System.Drawing; 6 using System.Text; 7 ...
  • 項目中考慮到容災、性能以及容量,一般會使用集群方式搭建redis。而當redis主伺服器存在故障,為了redis仍能正常運行,可以搭建redis哨兵,通過選舉方式重新建立主從關係。本文簡單講述主從建立和哨兵的配置。本機測試redis為Redis-x64-3.2.100(Windows下載地址:htt ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...