程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> C#將dataGridView中顯示的數據導出到Excel(超實用版)

C#將dataGridView中顯示的數據導出到Excel(超實用版)

編輯:C#入門知識

C#將dataGridView中顯示的數據導出到Excel(超實用版)


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.Office.Interop;
using Microsoft.Office.Interop.Excel;
using System.Windows.Forms;
using Excel = Microsoft.Office.Interop.Excel; 

public class ExprotToExcel
{ 
    public void  DataToExcel(DataGridView dgv,ToolStripProgressBar tempProgressBar,ToolStripStatusLabel toolstrip)
    {
        if (dgv.Rows.Count == 0)
        {
            MessageBox.Show("無數據"); return;
        }
        MessageBox.Show("開始生成要導出的數據", "導出提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
        Excel.Application excel = new Excel.Application();
        excel.Application.Workbooks.Add(true);
        excel.Visible = false;   
        for (int i = 0; i < dgv.ColumnCount; i++)
            excel.Cells[1, i + 1] = dgv.Columns[i].HeaderText;
        tempProgressBar.Visible = true;
        tempProgressBar.Minimum = 1;
        tempProgressBar.Maximum = dgv.RowCount;
        tempProgressBar.Step = 1;
        toolstrip.Visible = true;
        for (int i = 0; i < dgv.RowCount; i++)
        {
            for (int j = 0; j < dgv.ColumnCount; j++)
            {
                if (dgv[j, i].ValueType == typeof(string))
                {
                    excel.Cells[i + 2, j + 1] = "'" + dgv[j, i].Value.ToString();
                }
                else
                {
                    excel.Cells[i + 2, j + 1] = dgv[j, i].Value.ToString();
                }
            }
            toolstrip.Text = "|| 狀態:正在生成第 "+i+"/"+dgv.RowCount+" 個";
            tempProgressBar.Value = i + 1;
        }
        toolstrip.Text = "|| 狀態:生成成功!";
        MessageBox.Show("生成成功,請保存。","生成提示",MessageBoxButtons.OK,MessageBoxIcon.Information);
        excel.Visible = true;
    }
}

  1. 上一頁:
  2. 下一頁: