亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

asp.net DataGridView導出到Excel的三個方法[親測]

2024-07-10 13:22:13
字體:
來源:轉載
供稿:網友
#region DataGridView數據顯示到Excel   
/// <summary>    
/// 打開Excel并將DataGridView控件中數據導出到Excel   
/// </summary>    
/// <param name="dgv">DataGridView對象 </param>    
/// <param name="isShowExcle">是否顯示Excel界面 </param>    
/// <remarks>   
/// add com "Microsoft Excel 11.0 Object Library"   
/// using Excel=Microsoft.Office.Interop.Excel;   
/// </remarks>   
/// <returns> </returns>    
public bool DataGridviewShowToExcel(DataGridView dgv, bool isShowExcle)   
{   
    if (dgv.Rows.Count == 0)   
        return false;   
    //建立Excel對象    
    Excel.Application excel = new Excel.Application();   
    excel.Application.Workbooks.Add(true);   
    excel.Visible = isShowExcle;   
    //生成字段名稱    
    for (int i = 0; i < dgv.ColumnCount; i++)   
    {   
        excel.Cells[1, i + 1] = dgv.Columns[i].HeaderText;   
    }   
    //填充數據    
    for (int i = 0; i < dgv.RowCount - 1; 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();   
            }   
        }   
    }   
    return true;   
}  
#endregion   

#region DateGridView導出到csv格式的Excel   
/// <summary>   
/// 常用方法,列之間加/t,一行一行輸出,此文件其實是csv文件,不過默認可以當成Excel打開。   
/// </summary>   
/// <remarks>   
/// using System.IO;   
/// </remarks>   
/// <param name="dgv"></param>   
private void DataGridViewToExcel(DataGridView dgv)   
{   
    SaveFileDialog dlg = new SaveFileDialog();   
    dlg.Filter = "Execl files (*.xls)|*.xls";   
    dlg.FilterIndex = 0;   
    dlg.RestoreDirectory = true;   
    dlg.CreatePrompt = true;   
    dlg.Title = "保存為Excel文件";   

    if (dlg.ShowDialog() == DialogResult.OK)   
    {   
        Stream myStream;   
        myStream = dlg.OpenFile();   
        StreamWriter sw = new StreamWriter(myStream, System.Text.Encoding.GetEncoding(-0));   
        string columnTitle = "";   
        try  
        {   
            //寫入列標題   
            for (int i = 0; i < dgv.ColumnCount; i++)   
            {   
                if (i > 0)   
                {   
                    columnTitle += "/t";   
                }   
                columnTitle += dgv.Columns[i].HeaderText;   
            }   
            sw.WriteLine(columnTitle);   

            //寫入列內容   
            for (int j = 0; j < dgv.Rows.Count; j++)   
            {   
                string columnValue = "";   
                for (int k = 0; k < dgv.Columns.Count; k++)   
                {   
                    if (k > 0)   
                    {   
                        columnValue += "/t";   
                    }   
                    if (dgv.Rows[j].Cells[k].Value == null)   
                        columnValue += "";   
                    else  
                        columnValue += dgv.Rows[j].Cells[k].Value.ToString().Trim();   
                }   
                sw.WriteLine(columnValue);   
            }   
            sw.Close();   
            myStream.Close();   
        }   
        catch (Exception e)   
        {   
            MessageBox.Show(e.ToString());   
        }   
        finally  
        {   
            sw.Close();   
            myStream.Close();   
        }   
    }   
}   
#endregion  

#region DataGridView導出到Excel,有一定的判斷性   
/// <summary>    
///方法,導出DataGridView中的數據到Excel文件    
/// </summary>    
/// <remarks>   
/// add com "Microsoft Excel 11.0 Object Library"   
/// using Excel=Microsoft.Office.Interop.Excel;   
/// using System.Reflection;   
/// </remarks>   
/// <param name= "dgv"> DataGridView </param>    
public static void DataGridViewToExcel(DataGridView dgv)   
{  

 
    #region   驗證可操作性   

    //申明保存對話框    
    SaveFileDialog dlg = new SaveFileDialog();   
    //默然文件后綴    
    dlg.DefaultExt = "xls ";   
    //文件后綴列表    
    dlg.Filter = "EXCEL文件(*.XLS)|*.xls ";   
    //默然路徑是系統當前路徑    
    dlg.InitialDirectory = Directory.GetCurrentDirectory();   
    //打開保存對話框    
    if (dlg.ShowDialog() == DialogResult.Cancel) return;   
    //返回文件路徑    
    string fileNameString = dlg.FileName;   
    //驗證strFileName是否為空或值無效    
    if (fileNameString.Trim() == " ")   
    { return; }   
    //定義表格內數據的行數和列數    
    int rowscount = dgv.Rows.Count;   
    int colscount = dgv.Columns.Count;   
    //行數必須大于0    
    if (rowscount <= 0)   
    {   
        MessageBox.Show("沒有數據可供保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
        return;   
    }   

    //列數必須大于0    
    if (colscount <= 0)   
    {   
        MessageBox.Show("沒有數據可供保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
        return;   
    }   

    //行數不可以大于65536    
    if (rowscount > 65536)   
    {   
        MessageBox.Show("數據記錄數太多(最多不能超過65536條),不能保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
        return;   
    }   

    //列數不可以大于255    
    if (colscount > 255)   
    {   
        MessageBox.Show("數據記錄行數太多,不能保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
        return;   
    }   

    //驗證以fileNameString命名的文件是否存在,如果存在刪除它    
    FileInfo file = new FileInfo(fileNameString);   
    if (file.Exists)   
    {   
        try  
        {   
            file.Delete();   
        }   
        catch (Exception error)   
        {   
            MessageBox.Show(error.Message, "刪除失敗 ", MessageBoxButtons.OK, MessageBoxIcon.Warning);   
            return;   
        }   
    }  
    #endregion   
    Excel.Application objExcel = null;   
    Excel.Workbook objWorkbook = null;   
    Excel.Worksheet objsheet = null;   
    try  
    {   
        //申明對象    
        objExcel = new Microsoft.Office.Interop.Excel.Application();   
        objWorkbook = objExcel.Workbooks.Add(Missing.Value);   
        objsheet = (Excel.Worksheet)objWorkbook.ActiveSheet;   
        //設置EXCEL不可見    
        objExcel.Visible = false;   

        //向Excel中寫入表格的表頭    
        int displayColumnsCount = 1;   
        for (int i = 0; i <= dgv.ColumnCount - 1; i++)   
        {   
            if (dgv.Columns[i].Visible == true)   
            {   
                objExcel.Cells[1, displayColumnsCount] = dgv.Columns[i].HeaderText.Trim();   
                displayColumnsCount++;   
            }   
        }   
        //設置進度條    
        //tempProgressBar.Refresh();    
        //tempProgressBar.Visible   =   true;    
        //tempProgressBar.Minimum=1;    
        //tempProgressBar.Maximum=dgv.RowCount;    
        //tempProgressBar.Step=1;    
        //向Excel中逐行逐列寫入表格中的數據    
        for (int row = 0; row <= dgv.RowCount - 1; row++)   
        {   
            //tempProgressBar.PerformStep();    

            displayColumnsCount = 1;   
            for (int col = 0; col < colscount; col++)   
            {   
                if (dgv.Columns[col].Visible == true)   
                {   
                    try  
                    {   
                        objExcel.Cells[row + 2, displayColumnsCount] = dgv.Rows[row].Cells[col].Value.ToString().Trim();   
                        displayColumnsCount++;   
                    }   
                    catch (Exception)   
                    {   

                    }   

                }   
            }   
        }   
        //隱藏進度條    
        //tempProgressBar.Visible   =   false;    
        //保存文件    
        objWorkbook.SaveAs(fileNameString, Missing.Value, Missing.Value, Missing.Value, Missing.Value,   
                Missing.Value, Excel.XlSaveAsAccessMode.xlShared, Missing.Value, Missing.Value, Missing.Value,   
                Missing.Value, Missing.Value);   
    }   
    catch (Exception error)   
    {   
        MessageBox.Show(error.Message, "警告 ", MessageBoxButtons.OK, MessageBoxIcon.Warning);   
        return;   
    }   
    finally  
    {   
        //關閉Excel應用    
        if (objWorkbook != null) objWorkbook.Close(Missing.Value, Missing.Value, Missing.Value);   
        if (objExcel.Workbooks != null) objExcel.Workbooks.Close();   
        if (objExcel != null) objExcel.Quit();   

        objsheet = null;   
        objWorkbook = null;   
        objExcel = null;   
    }   
    MessageBox.Show(fileNameString + "/n/n導出完畢! ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   

}  

#endregion  
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
午夜精品蜜臀一区二区三区免费| 91av在线播放| 国产精品自拍偷拍视频| 亚洲电影免费观看高清完整版| 91av在线不卡| 欧美亚洲国产日韩2020| 欧美成年人视频网站欧美| 国产精品一区二区三区成人| 欧美亚洲国产精品| 欧美激情视频网| 亚洲黄页网在线观看| 亚洲一区二区三区四区在线播放| 国产日韩专区在线| 性日韩欧美在线视频| 欧美日韩国产综合新一区| 国产精品视频大全| 午夜精品一区二区三区在线视| 国产91精品高潮白浆喷水| 色综合91久久精品中文字幕| 久久久久久久久久婷婷| 亚洲精品视频中文字幕| 久久视频免费在线播放| 亚洲国模精品私拍| 久久久天堂国产精品女人| 久久夜精品va视频免费观看| 亚洲国产精品99久久| 国产大片精品免费永久看nba| 久久久国产影院| 91精品免费久久久久久久久| 国产三级精品网站| 亚洲第一av在线| 91伊人影院在线播放| 亚洲影院在线看| 热99在线视频| 91在线观看免费高清完整版在线观看| 中文字幕日韩欧美在线| 91日本视频在线| 亚洲一区中文字幕在线观看| 日韩影视在线观看| 亚洲欧美国产视频| 色一情一乱一区二区| 亚洲女同性videos| 91国产精品电影| 亚洲缚视频在线观看| 亚洲第一精品福利| 福利视频导航一区| 日韩av免费网站| 国产欧美日韩精品专区| 久热精品视频在线观看一区| 日韩av电影在线网| 欧美福利小视频| 欧美在线亚洲一区| 亚洲人成网站999久久久综合| 中文字幕精品在线视频| 欧美xxxx做受欧美.88| 国产日韩欧美一二三区| 久久亚洲综合国产精品99麻豆精品福利| 欧美国产视频日韩| 久久久久国产视频| 欧美日韩在线视频观看| 狠狠色香婷婷久久亚洲精品| 欧美制服第一页| 亚洲图中文字幕| 色婷婷亚洲mv天堂mv在影片| 亚洲无亚洲人成网站77777| 国产成人+综合亚洲+天堂| 国产中文字幕亚洲| 久久久免费观看视频| 久久久久久久久久久久久久久久久久av| 91久久嫩草影院一区二区| 中文字幕自拍vr一区二区三区| 日韩在线一区二区三区免费视频| 国产精品亚洲欧美导航| 国产精品v片在线观看不卡| 亚洲高清免费观看高清完整版| 日韩免费av一区二区| 国产精品福利网站| 欧美精品久久久久a| 国产精品亚洲精品| 国内外成人免费激情在线视频网站| 久久免费视频这里只有精品| 欧美在线视频一区二区| 日韩在线欧美在线| 亚洲精品小视频在线观看| 91久久精品国产91久久性色| 伊人成人开心激情综合网| 国产99久久久欧美黑人| 国产免费一区二区三区在线观看| 欧美日韩美女在线| 国产91露脸中文字幕在线| 九九久久久久久久久激情| 中文字幕日韩综合av| 2019亚洲男人天堂| 久久久久久久久中文字幕| 欧美性xxxx| 成人黄色av播放免费| 色黄久久久久久| 亚洲性xxxx| 91九色视频在线| 欧美在线视频在线播放完整版免费观看| 在线免费观看羞羞视频一区二区| 欧美电影院免费观看| 国产精品av在线| 色伦专区97中文字幕| 亚洲人成网7777777国产| 亚洲综合在线小说| 亚洲欧洲第一视频| 久久久精品免费| 91精品国产色综合久久不卡98口| 91国自产精品中文字幕亚洲| 亚洲a级在线播放观看| 国产视频欧美视频| 亚洲国产又黄又爽女人高潮的| 超碰91人人草人人干| 午夜精品久久久久久久99黑人| 亚洲成人激情在线| 亚洲天堂成人在线| 久久av红桃一区二区小说| 久久这里有精品| 精品久久香蕉国产线看观看gif| 国产精品老女人精品视频| 亚洲欧美制服中文字幕| 精品激情国产视频| 成人久久久久久久| 97视频在线免费观看| 97视频网站入口| 91久久精品国产91久久| 亚洲va欧美va在线观看| 成人免费视频在线观看超级碰| 日韩天堂在线视频| 国产99久久精品一区二区| 在线午夜精品自拍| 日本亚洲欧洲色α| 大量国产精品视频| 青青在线视频一区二区三区| 精品在线小视频| 黑人欧美xxxx| 成人a在线观看| 精品亚洲一区二区| 欧美一性一乱一交一视频| 久久视频在线视频| 日韩毛片在线看| 欧美精品在线极品| 欧美日韩激情视频| 欧美日韩视频免费播放| 日韩欧美国产黄色| 最新中文字幕亚洲| 国产精国产精品| 日韩欧美在线国产| 这里只有精品在线播放| 久久久午夜视频| 久久久人成影片一区二区三区| 91免费高清视频| 亚洲精品中文字| 7777免费精品视频| 欧美视频二区36p| www.久久久久久.com| 91黑丝高跟在线| 欧美体内谢she精2性欧美| 亚洲精品电影久久久| 欧美高清视频在线观看| 欧美高清无遮挡| 中文字幕日韩欧美在线视频| 亚洲综合国产精品|