• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
    當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

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

    來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:44:59
    文檔

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

    asp.net DataGridView導(dǎo)出到Excel的三個(gè)方法[親測(cè)]:#region DataGridView數(shù)據(jù)顯示到Excel /// <summary> /// 打開Excel并將DataGridView控件中數(shù)據(jù)導(dǎo)出到Excel /// </summary> /// <param name=dgv>DataGridView對(duì)象 </param> //
    推薦度:
    導(dǎo)讀asp.net DataGridView導(dǎo)出到Excel的三個(gè)方法[親測(cè)]:#region DataGridView數(shù)據(jù)顯示到Excel /// <summary> /// 打開Excel并將DataGridView控件中數(shù)據(jù)導(dǎo)出到Excel /// </summary> /// <param name=dgv>DataGridView對(duì)象 </param> //

    #region DataGridView數(shù)據(jù)顯示到Excel   
    /// <summary>    
    /// 打開Excel并將DataGridView控件中數(shù)據(jù)導(dǎo)出到Excel   
    /// </summary>    
    /// <param name="dgv">DataGridView對(duì)象 </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對(duì)象    
        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,一行一行輸出,此文件其實(shí)是csv文件,不過(guò)默認(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   驗(yàn)證可操作性   

        //申明保存對(duì)話框    
        SaveFileDialog dlg = new SaveFileDialog();   
        //默然文件后綴    
        dlg.DefaultExt = "xls ";   
        //文件后綴列表    
        dlg.Filter = "EXCEL文件(*.XLS)|*.xls ";   
        //默然路徑是系統(tǒng)當(dāng)前路徑    
        dlg.InitialDirectory = Directory.GetCurrentDirectory();   
        //打開保存對(duì)話框    
        if (dlg.ShowDialog() == DialogResult.Cancel) return;   
        //返回文件路徑    
        string fileNameString = dlg.FileName;   
        //驗(yàn)證strFileName是否為空或值無(wú)效    
        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("沒(méi)有數(shù)據(jù)可供保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
            return;   
        }   

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

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

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

        //驗(yàn)證以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  
        {   
            //申明對(duì)象    
            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  

    聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

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

    asp.net DataGridView導(dǎo)出到Excel的三個(gè)方法[親測(cè)]:#region DataGridView數(shù)據(jù)顯示到Excel /// <summary> /// 打開Excel并將DataGridView控件中數(shù)據(jù)導(dǎo)出到Excel /// </summary> /// <param name=dgv>DataGridView對(duì)象 </param> //
    推薦度:
    標(biāo)簽: net 導(dǎo)出excel data
    • 熱門焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 精品福利资源在线| 亚洲国产精品无码久久一区二区| 99精品久久久久久久婷婷| 91精品国产综合久久久久久| 欧美日韩精品一区二区三区不卡 | 无码精品一区二区三区免费视频 | 国产精品1024香蕉在线观看| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 国内精品视频九九九九| 久久激情亚洲精品无码?V| 国产原创精品视频| 久久亚洲精品成人AV| 思思久久99热免费精品6| 国产系列高清精品第一页| 久久久国产精品网站| 99国产欧美久久久精品蜜芽| 蜜国产精品jk白丝AV网站| 尤物TV国产精品看片在线| 欧美国产精品久久高清| 黑巨人与欧美精品一区 | 亚洲精品成人无码中文毛片不卡| 精品欧美激情在线看| 国产精品v欧美精品v日本精| 久久精品国产91久久麻豆自制| 国产精品丝袜黑色高跟鞋| 精品人妻无码一区二区色欲产成人 | 国产精品色视频ⅹxxx | 国产精品一区二区久久国产| 无码日韩精品一区二区三区免费| 亚洲AⅤ永久无码精品AA| 久久久久国产精品嫩草影院| 国产亚洲精品拍拍拍拍拍| 国产成人综合久久精品尤物| 午夜成人精品福利网站在线观看| 国产精品v欧美精品v日本精| 中文字幕亚洲精品资源网| 精品国产福利第一区二区三区| 国产成人精品视频播放| 成人午夜精品网站在线观看| 精品免费视在线观看| 精品久久香蕉国产线看观看亚洲|