一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

asp.net DataGridView導(dǎo)出到Excel的三個方法[親測]

#region DataGridView數(shù)據(jù)顯示到Excel   
/// <summary>    
/// 打開Excel并將DataGridView控件中數(shù)據(jù)導(dǎo)出到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;   
    }   
    //填充數(shù)據(jù)    
    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導(dǎo)出到csv格式的Excel   
/// <summary>   
/// 常用方法,列之間加/t,一行一行輸出,此文件其實是csv文件,不過默認(rèn)可以當(dāng)成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  
        {   
            //寫入列標(biāo)題   
            for (int i = 0; i < dgv.ColumnCount; i++)   
            {   
                if (i > 0)   
                {   
                    columnTitle += "/t";   
                }   
                columnTitle += dgv.Columns[i].HeaderText;   
            }   
            sw.WriteLine(columnTitle);   

            //寫入列內(nèi)容   
            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導(dǎo)出到Excel,有一定的判斷性   
/// <summary>    
///方法,導(dǎo)出DataGridView中的數(shù)據(jù)到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 ";   
    //默然路徑是系統(tǒng)當(dāng)前路徑    
    dlg.InitialDirectory = Directory.GetCurrentDirectory();   
    //打開保存對話框    
    if (dlg.ShowDialog() == DialogResult.Cancel) return;   
    //返回文件路徑    
    string fileNameString = dlg.FileName;   
    //驗證strFileName是否為空或值無效    
    if (fileNameString.Trim() == " ")   
    { return; }   
    //定義表格內(nèi)數(shù)據(jù)的行數(shù)和列數(shù)    
    int rowscount = dgv.Rows.Count;   
    int colscount = dgv.Columns.Count;   
    //行數(shù)必須大于0    
    if (rowscount <= 0)   
    {   
        MessageBox.Show("沒有數(shù)據(jù)可供保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
        return;   
    }   

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

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

    //列數(shù)不可以大于255    
    if (colscount > 255)   
    {   
        MessageBox.Show("數(shù)據(jù)記錄行數(shù)太多,不能保存 ", "提示 ", 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;   
        //設(shè)置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++;   
            }   
        }   
        //設(shè)置進(jìn)度條    
        //tempProgressBar.Refresh();    
        //tempProgressBar.Visible   =   true;    
        //tempProgressBar.Minimum=1;    
        //tempProgressBar.Maximum=dgv.RowCount;    
        //tempProgressBar.Step=1;    
        //向Excel中逐行逐列寫入表格中的數(shù)據(jù)    
        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)   
                    {   

                    }   

                }   
            }   
        }   
        //隱藏進(jìn)度條    
        //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  
    {   
        //關(guān)閉Excel應(yīng)用    
        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導(dǎo)出完畢! ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   

}  

#endregion  

AspNet技術(shù)asp.net DataGridView導(dǎo)出到Excel的三個方法[親測],轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 怡红院影院 | 久草免费在线色站 | 2021国产精品自在拍在线播放 | 国产成人91精品 | 欧美激情在线看 | 精品久久中文久久久 | avav亚洲| 色在线免费视频 | 精品久久久久久久久中文字幕 | 精品久久网站 | 国产精品被窝福利一区 | 六月丁香婷婷激情 | 成人精品在线观看 | 亚洲一区二区免费看 | 高清国产美女一级a毛片 | 一区二区在线免费视频 | 亚洲五月激情综合图片区 | 婷婷亚洲综合五月天小说在线 | 成人综合婷婷国产精品久久免费 | 欧美亚洲高清日韩成人 | 国产成人激烈叫床声视频对白 | 风间由美一区二区播放合集 | 激情亚洲 | 久久一日本道色综合久久m 久久伊人草 | 在线免费午夜视频 | 精品国产丝袜高跟鞋 | 综合网激情五月 | 综合在线视频精品专区 | 91国高清视频| 欧美一级视频免费 | 亚洲乱码在线视频 | 国产大陆亚洲精品国产 | 国产成人亚洲综合无 | 91视频色 | 国产一区二区三区鲁婷婷 | 久伊人网 | 国产成人精品自拍 | 日韩精品高清自在线 | 在线观看国产小视频 | 黄色影院7755 | 99久久伊人 |