上传读取Excel文件数据

 1         /// <summary>
 2         /// 上传读取Excel文件数据
 3         /// 来自http://www.cnblogs.com/cielwater
 4         /// </summary>
 5         /// <param name="form"></param>
 6         /// <returns></returns>
 7         public ActionResult AreaExcelFile(FormCollection form)
 8         {
 9             HttpPostedFileBase fileField = Request.Files["fileField"];
10             string path = Server.MapPath("~/Excel");
11             if (!Directory.Exists(path))
12             {
13                 Directory.CreateDirectory(path);
14             }
15             string flieName = fileField.FileName;
16             string fileExt = Path.GetExtension(flieName).ToLower().Substring(1);
17             //验证是否为Excel文件
18             if (fileExt != "xls" && fileExt != "xlsx")
19             {
20                 ModelState.AddModelError("file", "您选择的不是Excel文件");
21                 return View("ExcelFile");
22             }
23             string FileName = path + flieName.Substring(flieName.LastIndexOf("\\"));
24             fileField.SaveAs(FileName);
25             //读取excel文件,转换成dataset
26             string strConn = "";
27             if (fileExt == "xls")
28             {
29                 strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + FileName + ";Extended Properties=Excel 8.0;";
30             }
31             else if (fileExt == "xlsx")
32             {
33                 strConn = "Provider= Microsoft.ACE.OLEDB.12.0;Data Source=" + FileName + ";Extended Properties='Excel 8.0;HDR=False;IMEX=1'";
34             }
35             DataSet ds = new DataSet();
36             using (OleDbConnection conn = new OleDbConnection(strConn))
37             {
38                 conn.Open();
39                 //获取Excel表结构
40                 System.Data.DataTable sTable = conn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
41                 conn.Dispose();
42                 //遍历Excel文件所有表
43                 foreach (DataRow ExcelTable in sTable.Rows)
44                 {
45                     //读取表
46                     OleDbDataAdapter oada = new OleDbDataAdapter("select * from [" + ExcelTable[2] + "]", strConn);
47                     //写入DataSet
48                     oada.Fill(ds);
49                     //后面直接处理ds中的数据则可以
50                 }
51             }
52         }

 

posted @ 2014-03-04 15:30  Ciel Water  阅读(277)  评论(0编辑  收藏  举报