欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# 文件上傳下載(Excel導入,多線程下載)功能的實現(xiàn)代碼

 更新時間:2017年08月29日 17:10:50   作者:大白菜1990  
這篇文章主要介紹了C# 文件上傳下載(Excel導入,多線程下載)功能的實現(xiàn)代碼,需要的朋友可以參考下

廢話不多說了,直接給大家貼代碼,具體代碼如下所示:

//打開Excel文件,轉(zhuǎn)換為DataTable
      DataTable dtExcel;
    private void OpenFile()
    {
      OpenFileDialog dialog = new OpenFileDialog();
      dialog.Filter = "Microsoft Excel files(*.xls)|*.xls;*.xlsx"; //篩選打開文件類型 :圖片 *.jpg|*.jpg|*.bmp|*.bmp ;"音頻文|*.mp3;*.wma;*.aac;*.midi;*.wav" 等等
      if (dialog.ShowDialog() == DialogResult.OK)
      {
        dialogFileName = dialog.FileName;
        dtExcel = ExcelToDataTable(dialogFileName, "sheet1", true);
      }
    }
/// <summary>
  /// Excel轉(zhuǎn)Datatable
  /// </summary>
  /// <param name="fileName">文件名含后綴名</param>
  /// <param name="sheetName">Excel文件,頁名稱</param>
  /// <param name="isFirstRowColumn">是否將第一列作為表頭</param>
  /// <returns></returns>
  private DataTable ExcelToDataTable(string fileName, string sheetName, bool isFirstRowColumn)
  {
   IWorkbook workbook = null;
   FileStream fs = null;
   ISheet sheet = null;
   DataTable data = new DataTable();
   int startRow = 0;
   try
   {
    fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);
    if (fileName.IndexOf(".xlsx") > 0) // 2007版本
     workbook = new XSSFWorkbook(fs);
    else if (fileName.IndexOf(".xls") > 0) // 2003版本
     workbook = new HSSFWorkbook(fs);
    if (sheetName != null)
    {
     sheet = workbook.GetSheet(sheetName);
     if (sheet == null) //如果沒有找到指定的sheetName對應的sheet,則嘗試獲取第一個sheet
     {
      sheet = workbook.GetSheetAt(0);
     }
    }
    else
    {
     sheet = workbook.GetSheetAt(0);
    }
    if (sheet != null)
    {
     IRow firstRow = sheet.GetRow(0);
     int cellCount = firstRow.LastCellNum; //一行最后一個cell的編號 即總的列數(shù)
     if (isFirstRowColumn)
     {
      for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
      {
       ICell cell = firstRow.GetCell(i);
       if (cell != null)
       {
        string cellValue = cell.StringCellValue;
        if (cellValue != null)
        {
         DataColumn column = new DataColumn(cellValue);
         data.Columns.Add(column);
        }
       }
      }
      startRow = sheet.FirstRowNum + 1;
     }
     else
     {
      startRow = sheet.FirstRowNum;
     }
     //最后一列的標號
     int rowCount = sheet.LastRowNum;
     for (int i = startRow; i <= rowCount; ++i)
     {
      IRow row = sheet.GetRow(i);
      if (row == null) continue; //沒有數(shù)據(jù)的行默認是null       
      DataRow dataRow = data.NewRow();
      for (int j = row.FirstCellNum; j < cellCount; ++j)
      {
       if (row.GetCell(j) != null) //同理,沒有數(shù)據(jù)的單元格都默認是null
        dataRow[j] = row.GetCell(j).ToString();
      }
      data.Rows.Add(dataRow);
     }
    }
    return data;
   }
   catch (Exception ex)
   {
    MyMessageBox.Show(ex.Message);
    return null;
   }
  }

文件下載:

private void DownLoad()
  {
   if (impdefineBM != null)
   {
    FolderBrowserDialog path = new FolderBrowserDialog();
    path.ShowDialog();
    if (path != null && path.SelectedPath != "")
    {
     string url = @"http://192.168.1.1/XX.xls";  //下載地址
     string name = "FileName";              // 文件名稱
     string savefilepath = path.SelectedPath + "\\" + name + url.Substring(url.LastIndexOf(".")); //注意:下載文件名的命名 ,可根據(jù)實際需求調(diào)整調(diào)用的文件創(chuàng)建方式
     MultiDownload download = new MultiDownload(5, url, savefilepath); //調(diào)用多線程下載
     download.Start();
    }
   }
  }
 #region 多線程下載
  public class MultiDownload
  {
   #region 變量
   private int _threadNum;    //線程數(shù)量
   private long _fileSize;    //文件大小
   private string _fileUrl;   //文件地址
   private string _fileName;   //文件名
   private string _savePath;   //保存路徑
   private short _threadCompleteNum; //線程完成數(shù)量
   private bool _isComplete;   //是否完成
   private volatile int _downloadSize; //當前下載大小(實時的)
   private Thread[] _thread;   //線程數(shù)組
   private List<string> _tempFiles = new List<string>();
   private object locker = new object();
   #endregion
   #region 屬性
   /// <summary>
   /// 文件名
   /// </summary>
   public string FileName
   {
    get
    {
     return _fileName;
    }
    set
    {
     _fileName = value;
    }
   }
   /// <summary>
   /// 文件大小
   /// </summary>
   public long FileSize
   {
    get
    {
     return _fileSize;
    }
   }
   /// <summary>
   /// 當前下載大小(實時的)
   /// </summary>
   public int DownloadSize
   {
    get
    {
     return _downloadSize;
    }
   }
   /// <summary>
   /// 是否完成
   /// </summary>
   public bool IsComplete
   {
    get
    {
     return _isComplete;
    }
   }
   /// <summary>
   /// 線程數(shù)量
   /// </summary>
   public int ThreadNum
   {
    get
    {
     return _threadNum;
    }
   }
   /// <summary>
   /// 保存路徑
   /// </summary>
   public string SavePath
   {
    get
    {
     return _savePath;
    }
    set
    {
     _savePath = value;
    }
   }
   #endregion
   /// <summary>
   /// 構(gòu)造函數(shù)
   /// </summary>
   /// <param name="threahNum">線程數(shù)量</param>
   /// <param name="fileUrl">文件Url路徑</param>
   /// <param name="savePath">本地保存路徑</param>
   public MultiDownload(int threahNum, string fileUrl, string savePath)
   {
    this._threadNum = threahNum;
    this._thread = new Thread[threahNum];
    this._fileUrl = fileUrl;
    this._savePath = savePath;
   }
   public void Start()
   {
    HttpWebRequest request = (HttpWebRequest)WebRequest.Create(_fileUrl);
    HttpWebResponse response = (HttpWebResponse)request.GetResponse();
    _fileSize = response.ContentLength;
    int singelNum = (int)(_fileSize / _threadNum);  //平均分配
    int remainder = (int)(_fileSize % _threadNum);  //獲取剩余的
    request.Abort();
    response.Close();
    for (int i = 0; i < _threadNum; i++)
    {
     List<int> range = new List<int>();
     range.Add(i * singelNum);
     if (remainder != 0 && (_threadNum - 1) == i) //剩余的交給最后一個線程
      range.Add(i * singelNum + singelNum + remainder - 1);
     else
      range.Add(i * singelNum + singelNum - 1);
     //下載指定位置的數(shù)據(jù)
     int[] ran = new int[] { range[0], range[1] };
     _thread[i] = new Thread(new ParameterizedThreadStart(Download));
     _thread[i].Name = System.IO.Path.GetFileNameWithoutExtension(_fileUrl) + "_{0}".Replace("{0}", Convert.ToString(i + 1));
     _thread[i].Start(ran);
    }
    //MessageBox.Show("下載完成!");
   }
   private void Download(object obj)
   {
    Stream httpFileStream = null, localFileStram = null;
    try
    {
     int[] ran = obj as int[];
     string tmpFileBlock = System.IO.Path.GetTempPath() + Thread.CurrentThread.Name + ".tmp";
     _tempFiles.Add(tmpFileBlock);
     HttpWebRequest httprequest = (HttpWebRequest)WebRequest.Create(_fileUrl);
     httprequest.AddRange(ran[0], ran[1]);
     HttpWebResponse httpresponse = (HttpWebResponse)httprequest.GetResponse();
     httpFileStream = httpresponse.GetResponseStream();
     localFileStram = new FileStream(tmpFileBlock, FileMode.Create);
     byte[] by = new byte[5000];
     int getByteSize = httpFileStream.Read(by, 0, (int)by.Length); //Read方法將返回讀入by變量中的總字節(jié)數(shù)
     while (getByteSize > 0)
     {
      Thread.Sleep(20);
      lock (locker) _downloadSize += getByteSize;
      localFileStram.Write(by, 0, getByteSize);
      getByteSize = httpFileStream.Read(by, 0, (int)by.Length);
     }
     lock (locker) _threadCompleteNum++;
    }
    catch (Exception ex)
    {
     throw new Exception(ex.Message.ToString());
    }
    finally
    {
     if (httpFileStream != null) httpFileStream.Dispose();
     if (localFileStram != null) localFileStram.Dispose();
    }
    if (_threadCompleteNum == _threadNum)
    {
     Complete();
     _isComplete = true;
    }
   }
   /// <summary>
   /// 下載完成后合并文件塊
   /// </summary>
   private void Complete()
   {
    Stream mergeFile = null;
    BinaryWriter AddWriter = null;
    try
    {
     using (mergeFile = new FileStream(@_savePath, FileMode.Create)) //根據(jù)實際情況調(diào)整FileMode
     {
      AddWriter = new BinaryWriter(mergeFile);
      foreach (string file in _tempFiles)
      {
       using (FileStream fs = new FileStream(file, FileMode.Open))
       {
        BinaryReader TempReader = new BinaryReader(fs);
        AddWriter.Write(TempReader.ReadBytes((int)fs.Length));
        TempReader.Close();
       }
       File.Delete(file);
      }
     }
     MyMessageBox.Show("下載完成!");
    }
    catch (Exception ex)
    {
     throw new Exception(ex.Message);
    }
    finally
    {
     if (AddWriter != null)
     {
      AddWriter.Close();
      AddWriter.Dispose();
     }
     if (mergeFile != null)
     {
      mergeFile.Close();
      mergeFile.Dispose();
     }
    }
   }
  }

總結(jié)

以上所述是小編給大家介紹的C# 文件上傳下載(Excel導入,多線程下載)功能的實現(xiàn)代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • C#程序終極調(diào)試實現(xiàn)windbg的時間旅行

    C#程序終極調(diào)試實現(xiàn)windbg的時間旅行

    這篇文章主要介紹了C#程序終極調(diào)試實現(xiàn)windbg的時間旅行示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • C#中partial關鍵字的作用

    C#中partial關鍵字的作用

    這篇文章主要介紹了C#中partial關鍵字的作用詳解,包括局部類型概念和注意點介紹,非常不錯,具有參考借鑒價值,需要的的朋友參考下
    2017-03-03
  • C#中using關鍵字的使用方法示例

    C#中using關鍵字的使用方法示例

    在C#語句中,將using關鍵字作為一個語句時,該語句的作用是定義一個用大括號規(guī)定的范圍,在該范圍的末尾,系統(tǒng)會立即釋放using后小括號內(nèi)指定的對象,下面這篇文章主要給大家介紹了關于C#中using關鍵字使用的相關資料,需要的朋友可以參考下
    2022-06-06
  • C#如何讀取Txt大數(shù)據(jù)并更新到數(shù)據(jù)庫詳解

    C#如何讀取Txt大數(shù)據(jù)并更新到數(shù)據(jù)庫詳解

    這篇文章主要給大家介紹了關于C#如何讀取Txt大數(shù)據(jù)并更新到數(shù)據(jù)庫的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用C#具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08
  • 使用C#快速搭建一個在windows運行的exe應用

    使用C#快速搭建一個在windows運行的exe應用

    這篇文章主要介紹了使用C#快速搭建一個在windows運行的exe應用,這是一個比較舊的內(nèi)容,但是一直都沒有空寫,今天花點時間,把我掌握的C# 分享給初學的人或者感興趣的人,希望能對你有一定幫助,感興趣的小伙伴跟著小編一起來看看吧
    2024-07-07
  • C# .Net實現(xiàn)灰度圖和HeatMap熱力圖winform(進階)

    C# .Net實現(xiàn)灰度圖和HeatMap熱力圖winform(進階)

    本文主要介紹了C# .NET實現(xiàn)簡易灰度圖和酷炫HeatMap熱力圖winform,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • C#使用CallContext緩存線程數(shù)據(jù)

    C#使用CallContext緩存線程數(shù)據(jù)

    這篇文章介紹了C#使用CallContext緩存線程數(shù)據(jù)的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • C#實現(xiàn)簡單工廠模式

    C#實現(xiàn)簡單工廠模式

    這篇文章介紹了C#實現(xiàn)簡單工廠模式的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • C#使用表達式樹(LambdaExpression)動態(tài)更新類的屬性值(示例代碼)

    C#使用表達式樹(LambdaExpression)動態(tài)更新類的屬性值(示例代碼)

    這篇文章主要介紹了C#使用表達式樹(LambdaExpression)動態(tài)更新類的屬性值,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • c#中如何去除字符串左邊的0

    c#中如何去除字符串左邊的0

    這篇文章主要介紹了c#中如何去除字符串左邊的0問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05

最新評論