zoukankan      html  css  js  c++  java
  • [zz]winform导入excel

    winfrom导入excel内容,要求能够excel中多个工作簿的内容。代码如下:

    #region 导入excel数据
            private void button2_Click(object sender, EventArgs e)
            {
                OpenFileDialog openFileDialog = new OpenFileDialog();
                 openFileDialog.Filter = "表格文件 (*.xls)|*.xls";
                 openFileDialog.RestoreDirectory = true;
                 openFileDialog.FilterIndex = 1;
                 if (openFileDialog.ShowDialog() == DialogResult.OK)
                 {
                     Import(openFileDialog.FileName);
                 }
            }
    
            /// <summary>
            /// 导入excel数据
            /// </summary>
            /// <param name="filePath"></param>
            /// <returns></returns>
            public static bool Import(string filePath)
            {
                try
                {
                    //Excel就好比一个数据源一般使用
                    //这里可以根据判断excel文件是03的还是07的,然后写相应的连接字符串
                    string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + filePath + ";" + "Extended Properties=Excel 8.0;";
                    OleDbConnection con = new OleDbConnection(strConn);
                    con.Open();
                    string[] names = GetExcelSheetNames(con);
                    if (names.Length > 0)
                    {
                        foreach (string name in names)
                        {
                            OleDbCommand cmd = con.CreateCommand();
                            cmd.CommandText = string.Format(" select * from [{0}]", name);//[sheetName]要如此格式
                            OleDbDataReader odr = cmd.ExecuteReader();
                            while (odr.Read())
                            {
                                if (odr[0].ToString() == "序号")//过滤列头  按你的实际Excel文件
                                    continue;
                               //数据库添加操作
                                /*进行非法值的判断
                                 * 添加数据到数据表中
                                 * 添加数据时引用事物机制,避免部分数据提交
                                 * Add(odr[1].ToString(), odr[2].ToString(), odr[3].ToString());//数据库添加操作,Add方法自己写的
                                 * */
                               
                            }
                            odr.Close();
                        }
                    }
                    return true;
                }
                catch (Exception)
                {
                    return false;
                }
            }
    
            /// <summary>
             /// 查询表名
             /// </summary>
             /// <param name="con"></param>
             /// <returns></returns>
             public static string[] GetExcelSheetNames(OleDbConnection con)
             {
                 try
                 {
                    System.Data.DataTable  dt = con.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new[] { null, null, null, "Table" });//检索Excel的架构信息
                     var sheet = new string[dt.Rows.Count];
                     for (int i = 0, j = dt.Rows.Count; i < j; i++)
                     {
                         //获取的SheetName是带了$的
                         sheet[i] = dt.Rows[i]["TABLE_NAME"].ToString();
                     }
                     return sheet;
                 }
                 catch
                 {
                     return null;
                 }
             }
    
            //下面这种方法获取excel Worksheets Name时,提示无法访问该exceL文件,所以改为上面获取工作簿名的方式
    
            ///// <summary>
            ///// 获得excel sheet所有工作簿名字
            ///// </summary>
            ///// <param name="filePath"></param>
            ///// <returns></returns>
            //public static string[] GetExcelSheetNames(string filePath)
            //{
            //    Microsoft.Office.Interop.Excel.ApplicationClass excelApp = new Microsoft.Office.Interop.Excel.ApplicationClass();
            //    Microsoft.Office.Interop.Excel.Workbooks wbs = excelApp.Workbooks;
            //    Microsoft.Office.Interop.Excel.Workbook wb = wbs.Open(filePath, Type.Missing, Type.Missing, Type.Missing, Type.Missing,
            //    Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing,
            //    Type.Missing, Type.Missing, Type.Missing, Type.Missing);
            //    int count = wb.Worksheets.Count;
            //    string[] names = new string[count];
            //    for (int i = 1; i <= count; i++)
            //    {
            //        names[i - 1] = ((Microsoft.Office.Interop.Excel.Worksheet)wb.Worksheets[i]).Name;
            //    }
            //    return names;
            //}
            #endregion
  • 相关阅读:
    将驱动程序添加到脱机 Windows 映像
    python3 字符串格式输出,左边补0
    启动tomcat三种方式
    关于杭州房价的一些思考
    《经济学原理 -- 生产要素市场》笔记
    《经济学原理 -- 外部性》笔记
    《经济学原理 -- 弹性及其应用》笔记
    《经济学原理 -- 供给与需求的市场力量》笔记
    《经济学原理 -- 像经济学家一样思考》笔记
    《经济学院原理 -- 经济学十大原理》笔记
  • 原文地址:https://www.cnblogs.com/Raywang80s/p/6906195.html
Copyright © 2011-2022 走看看