打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
C#如何读取Excel表格数据并显示到GridView控件

protected void Button1_Click(object sender, EventArgs e)
    ...{
        string filepath=FileUpload1.PostedFile.FileName;
        ReadExcel(filepath, gdBom);
    }
    public void ReadExcel(string sExcelFile,GridView dgBom)
    ...{
        DataTable ExcelTable;
        DataSet ds = new DataSet();
        //Excel的连接
        OleDbConnection objConn = newOleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" +sExcelFile + ";" + "Extended Properties=Excel 8.0;");
        objConn.Open();
        DataTable schemaTable = objConn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
        string tableName = schemaTable.Rows[0][2].ToString().Trim();//获取 Excel 的表名,默认值是sheet1
        string strSql = "select * from [" + tableName + "]";
        OleDbCommand objCmd = new OleDbCommand(strSql, objConn);
        OleDbDataAdapter myData = new OleDbDataAdapter(strSql, objConn);
        myData.Fill(ds, tableName);//填充数据

        dgBom.DataSource =ds;
        dgBom.DataBind();
        objConn.Close();
      
        ExcelTable = ds.Tables[tableName];
        int iColums = ExcelTable.Columns.Count;//列数
        int iRows = ExcelTable.Rows.Count;//行数

        //定义二维数组存储 Excel 表中读取的数据
        string[,] storedata = new string[iRows, iColums];
    
        for(int i=0;i<ExcelTable.Rows.Count;i++)
            for (int j = 0; j < ExcelTable.Columns.Count; j++)
            ...{
                //将Excel表中的数据存储到数组
                storedata[i, j] = ExcelTable.Rows[i][j].ToString();

            }
        int excelBom = 0;//记录表中有用信息的行数,有用信息是指除去表的标题和表的栏目,本例中表的用用信息是从第三行开始
        //确定有用的行数
        for (int k = 2; k < ExcelTable.Rows.Count; k++)
            if (storedata[k, 1] != "")
                excelBom++;
        if (excelBom == 0)
        ...{
            Response.Write("<script language=javascript>alert('您导入的表格不合格式!')</script>");
        }
        else
        ...{
            //LoadDataToDataBase(storedata,excelBom)//该函数主要负责将 storedata 中有用的数据写入到数据库中,在此不是问题的关键省略
        }

    }
运行效果如下图:选择BOM表的路径,点确定后

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
C#使用 OleDbConnection 连接读取Excel
.net获得excel的sheet名字
excel批量导入数据
Windows8可拖拽的GridViewItem
vb读取excel内容
GridView+存储过程实现'真分页'
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服