• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ASP.NET中上传EXCEL文件一个比较快的方法

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

public string SaveUploadExcel(HttpPostedFile hpf)//验证Excel文件的正确性
  {
       //检查文件格式各文件大小是否有效
       if(hpf == null || hpf.ContentLength < 1 || System.IO.Path.GetExtension(hpf.FileName).ToLower() != ".xls")
       {
            throw new InnerException("文件上传失败或文件格式不正确。!");
       }

       //保存文件
       try
       {
            string fileFullName = MakeFileName();
            hpf.SaveAs(fileFullName);
            return fileFullName;
       }
       catch//(Exception ex)
       {
            throw new InnerException("保存文件失败。");// + ex.Message);
       }
  }

  public string MakeFileName()//生成唯一文件名的Excel文件
  {
       string filePath = HttpContext.Current.Server.MapPath(HttpContext.Current.Request.ApplicationPath)         +"\\uploadFiles\\PlanExcel";
       if(!Directory .Exists(filePath))
            Directory.CreateDirectory(filePath);
       
string fileName = Convert.ToString(HttpContext.Current.Session["UserID"])  + "_"
        + DateTime.Now.ToString("yyyyMMddHHmmss")
        + ".xls";

       return filePath + "\\" + fileName;
  }

public DataTable ReadNoHeadExcelData(string fileFullName)//读取Excel文件最后返回一个DataTable,可以在返回DataTable后对这个DataTable进行检验!
  {
        string excelNoHeadConnStr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties=\"Excel 8.0;HDR=NO;IMEX=1;\"";//连接字符串
       OleDbConnection oleCn =new OleDbConnection();
       try
       {
            string currConnStr = string.Format(excelNoHeadConnStr, fileFullName);//连接字符串
            oleCn.ConnectionString = currConnStr;                    
            DataTable dt = new DataTable();
            oleCn.Open();
            string excelBookName = oleCn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null).Rows[0][2].ToString();
            if(excelBookName!=string.Empty && excelBookName.Trim()!="")
            {
                 string currSqlStr = string.Format(excelSqlStr, excelBookName);//sql字符串
                 OleDbCommand oleCmd = new OleDbCommand(currSqlStr, oleCn);
                 OleDbDataAdapter oleDda = new OleDbDataAdapter(oleCmd);
                 oleDda.Fill(dt);               
            }
            oleCn.Close();                
            return dt;
       }
       catch
       {
            string errorMsg="Excel文件格式不对,请尝试用excel打开该文件检查内容并另存一下,确保成为正确的excel文件,再重新上传";
            System.Web.HttpContext.Current.Response.Write("<script>alert('"+ errorMsg  +"')</script>");
            oleCn.Close(); 
            return null;
        }
  }


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
打造通用ASP.NET数据分页控件发布时间:2022-07-10
下一篇:
asp.net Treeview发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap