ASP.NET导入excel时提示外部表不是预期的格式

admin 发布时间:2015-05-27 分类:.NET 阅读:4795次 2 条评论

出现此问题有几种可能性。

1、EXCEL版本不对,程序只能用2003excel格式文件导入,而你使用更高版本的excel,会提示此问题。

代码解决:

using System.Data.OleDb;
using System.Data;
public void ReadExcelFiless()
{
    //string strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + Server.MapPath("ExcelFiles/MyExcelFile.xls") + ";Extended Properties='Excel 8.0; HDR=Yes; IMEX=1'"; //此连接只能操作Excel2007之前(.xls)文件
    string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + Server.MapPath("ExcelFiles/Mydata2007.xlsx") + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; //此连接可以操作.xls与.xlsx文件 (支持Excel2003 和 Excel2007 的连接字符串)
//备注: "HDR=yes;"是说Excel文件的第一行是列名而不是数据,"HDR=No;"正好与前面的相反。
//"IMEX=1 "如果列中的数据类型不一致,使用"IMEX=1"可必免数据类型冲突。 
    OleDbConnection conn = new OleDbConnection(strConn);
    OleDbDataAdapter adp = new OleDbDataAdapter("Select * from [Sheet1$]", conn);
    DataSet ds = new DataSet();
    adp.Fill(ds, "Book1");
    this.GridView1.DataSource = ds.Tables["Book1"].DefaultView;
    this.GridView1.DataBind(); 
}

2、EXCEL文件格式不正确。可能并不是excel格式的文件,后缀是xls等并不能说明该文件是excel格式文件。

如我们公司的文档及excel都是会加密的,直接用公司的文档导入会提示此问题,申请解密之后就正常了。


关键字词: EXCEL

已有2条留言

发表评论:

◎欢迎您的参与讨论。