<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

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

        來源:懂視網 責編:小采 時間:2020-11-27 22:44:59
        文檔

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

        asp.net DataGridView導出到Excel的三個方法[親測]:#region DataGridView數據顯示到Excel /// <summary> /// 打開Excel并將DataGridView控件中數據導出到Excel /// </summary> /// <param name=dgv>DataGridView對象 </param> //
        推薦度:
        導讀asp.net DataGridView導出到Excel的三個方法[親測]:#region DataGridView數據顯示到Excel /// <summary> /// 打開Excel并將DataGridView控件中數據導出到Excel /// </summary> /// <param name=dgv>DataGridView對象 </param> //

        #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  

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

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

        asp.net DataGridView導出到Excel的三個方法[親測]:#region DataGridView數據顯示到Excel /// <summary> /// 打開Excel并將DataGridView控件中數據導出到Excel /// </summary> /// <param name=dgv>DataGridView對象 </param> //
        推薦度:
        標簽: net 導出excel data
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 成年女人色毛片免费看| 91精品免费国产高清在线| 日本视频免费高清一本18 | 久久久久亚洲av无码专区喷水| 久久久久亚洲av无码专区| 亚洲欧洲日韩国产一区二区三区| 午夜亚洲WWW湿好爽| 岛国岛国免费V片在线观看| 免费播放一区二区三区| 成人性生交大片免费看无遮挡 | 免费网站看v片在线香蕉| 亚洲精品麻豆av| 亚洲成人激情在线| 最新国产成人亚洲精品影院| 男男黄GAY片免费网站WWW| 两个人看的www免费视频| 香蕉97超级碰碰碰免费公| 五月天婷亚洲天综合网精品偷| 亚洲va久久久噜噜噜久久天堂| 激情综合亚洲色婷婷五月| 美女尿口扒开图片免费| 人人玩人人添人人澡免费| 破了亲妺妺的处免费视频国产| 亚洲精品亚洲人成在线观看| 在线综合亚洲欧洲综合网站| 国产美女视频免费观看的网站 | 亚洲高清中文字幕免费| 久久久久无码专区亚洲av| 亚洲影视一区二区| 国产福利免费视频 | 精品一区二区三区高清免费观看| 久久久久免费看成人影片| 在线观着免费观看国产黄| 久久久亚洲欧洲日产国码农村| 亚洲日韩精品国产一区二区三区| 中文字幕免费在线看线人动作大片| 久久99九九国产免费看小说| 国产成人亚洲精品影院| 中文文字幕文字幕亚洲色| 丝袜足液精子免费视频| 日韩一区二区三区免费体验|