原文发布时间为:2008-10-16 —— 来源于本人的百度文章 [由搬家工具导入]

//将需要导入的文件上传到服务器  
        string filePath = "", fileExtName = "";  
        //string myFileName;//用不到,但也写上吧  
        string myPath;  
        string FullName = "";//保存文件的完整文件名  
        if(fileUp.PostedFile.FileName!="")  
        {  
            //取得文件路径   
            filePath = fileUp.PostedFile.FileName;  
            //取得文件扩展名  
            fileExtName = filePath.Substring(filePath.LastIndexOf(".")+1);  
            //判断是否为Excel文件  
            if (fileExtName == "xls")  
            {  
                try
                {  
                    //取得与web服务器上指定的虚拟路径相对应的物理路径  
                    myPath = Server.MapPath("Upfiles/");  
                    //取得文件名  
                    //myFileName = filePath.Substring(filePath.LastIndexOf("")+1);  
                    //取得当前时间,以“时时分分秒秒”来命名,以免重复  
                    string strDateName = DateTime.Now.ToString("hhmmss");  
                    //保存上传文件到指定目录  
                    FullName = myPath + strDateName + "." + fileExtName;  
                    fileUp.PostedFile.SaveAs(FullName);  
                }  
                catch (Exception ex)  
                {  
                    Response.Write(ex.Message);  
                }  
            }  
            else
            {  
                Page.RegisterStartupScript("","<SCRIPT>alert('文件格式不正确');</SCRIPT>");  
                return;  
            }  
        }  
        //读取Excel中的内容  
        string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + FullName + ";Extended Properties=Excel 8.0;";  
        OleDbConnection connxls = new OleDbConnection(strConn);  
        if(connxls.State.ToString()=="Closed")  
        {  
            connxls.Open();  
        }  
        string sqlExcel=("select * from [Sheet1$]");  
        OleDbDataAdapter myDa = new OleDbDataAdapter(sqlExcel,connxls);  
        DataSet myDs = new DataSet();  
        myDa.Fill(myDs);  
        if (myDs.Tables[0].Rows.Count > 0)  
        {  
            /***************将数据绑定到gridview*****************************************************/
            try
            {  

                GridView1.DataSource = myDs.Tables[0].DefaultView;  
                GridView1.DataBind();  
   
            }  
            catch (Exception ex)  
            {  
                Response.Write("读取出错" + ex.Message);  
            }  
            /***************绑定完成******************************************************************/

            /********将数据导入到数据库,如果有对应的SQLserver2000数据库,要求字段要一一对应**********/
            string mySql = "";  
            //链接SQLserver2005数据库  
            string sqlConn = "server=.\\SQLEXPRESS;database=learning;user id=sa;pwd=sasasa";  
            SqlConnection con = new SqlConnection(sqlConn);  
            if(con.State.ToString()=="Closed")  
            {  
                con.Open();  
            }  
            SqlCommand myCmd = new SqlCommand();  
            //将数据逐行写入到数据库中  
            for (int i = 0; i < myDs.Tables[0].Rows.Count; i++)  
            {  
                //数据库中三个字段,所以插入三列  
                mySql = ("insert into myInfo(myname,sex,mylike) values('" + myDs.Tables[0].Rows[i][0].ToString() + "',"+  
                         "'" + myDs.Tables[0].Rows[i][1].ToString() + "','" + myDs.Tables[0].Rows[i][2].ToString() + "')");  
                myCmd.Connection = con;  
                myCmd.CommandText = mySql;  
                try
                {  
                    myCmd.ExecuteNonQuery();  
                }  
                catch (Exception ex)  
                {  
                    Response.Write("将数据插入数据库时出错" + ex.Message);  
                }  
            }  
            Response.Write("<SCRIPT>alert('数据已成功导入到数据库!');</SCRIPT>");  
            if(con.State.ToString()=="Open")  
            {  
                con.Close();  
            }  
            /*********导入数据库完成******************************************************************/
        }  
        else
        {  
            Page.RegisterStartupScript("","<SCRIPT>alert('Excel中没有数据!');</SCRIPT>");  
        }  
        if(connxls.State.ToString()=="Open")  
        {  
            connxls.Close();  
        }  

gridview读取Excel文件中的数据,并将其导入数据库的更多相关文章

  1. 用python的pandas读取excel文件中的数据

    一.读取Excel文件   使用pandas的read_excel()方法,可通过文件路径直接读取.注意到,在一个excel文件中有多个sheet,因此,对excel文件的读取实际上是读取指定文件.并 ...

  2. matlab读取excel文件中的数据

    1.读取sheet1中的所有数据 1.1首先我们建立一个sheet表,表名为‘111’ 1.2 默认这些文本以及数字都放在sheet1中,我们将此excel选入当前工作目录(必要步骤), 选入当前工作 ...

  3. Newtonsoft.Json读取txt文件中json数据并存到SQL service 数据库!

    using System; using System.Collections.Generic; using System.Text; using System.IO; using Newtonsoft ...

  4. Java读取、写入、处理Excel文件中的数据(转载)

    原文链接 在日常工作中,我们常常会进行文件读写操作,除去我们最常用的纯文本文件读写,更多时候我们需要对Excel中的数据进行读取操作,本文将介绍Excel读写的常用方法,希望对大家学习Java读写Ex ...

  5. [Python]将Excel文件中的数据导入MySQL

    Github Link 需求 现有2000+文件夹,每个文件夹下有若干excel文件,现在要将这些excel文件中的数据导入mysql. 每个excel文件的第一行是无效数据. 除了excel文件中已 ...

  6. 读取Excel文件中的单元格的内容和颜色

    怎样读取Excel文件中的单元格的内容和颜色 先创建一个Excel文件,在A1和A2中随意输入内容,设置A1的字体颜色为红色,A2的背景为黄色.需要 using Excel = Microsoft.O ...

  7. 利用java反射机制实现读取excel表格中的数据

    如果直接把excel表格中的数据导入数据库,首先应该将excel中的数据读取出来. 为了实现代码重用,所以使用了Object,而最终的结果是要获取一个list如List<User>.Lis ...

  8. 用Python的pandas框架操作Excel文件中的数据教程

    用Python的pandas框架操作Excel文件中的数据教程 本文的目的,是向您展示如何使用pandas 来执行一些常见的Excel任务.有些例子比较琐碎,但我觉得展示这些简单的东西与那些你可以在其 ...

  9. .Net读取Excel文件时丢失数据的问题 (转载)

    相信很多人都试过通过OleDB读取Excel文件,这种方法效率十分高,只是有一点会让人十分头痛,就是当一列中既有混合型数据,又有纯数据时,往往容易丢失数据. 百度过后,改连接字符串 “HDR=YES; ...

随机推荐

  1. IOStime处理

    对时间处理,在开发时,时常碰到.一般有获取具体的年月日和星期,两个不同时间的差,某一天的前一天或后一天等 .现在只介绍获取具体的年月日和星期,及某一天的前一天或后一天的方法: 对时间的处理一般都会用到 ...

  2. Struts2控制文件的上传与下载

    Struts2控制文件上传与下载的几个注意事项: (1)必须将表单的method设置为post,将enctype设置为multipart/from-data.只有这样,浏览器才会把用户选择文件的二进制 ...

  3. php 批量依照ID建立 文件

    <?php // 登录验证 include_once('inc/conn.php'); // sql查询 $sql="SELECT * FROM zcgl ";// $res ...

  4. 洛谷 P1434 滑雪

    题目描述 Michael喜欢滑雪.这并不奇怪,因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你.Michael想知道在一个区域中最长 ...

  5. Redhat5 安装序列号及版本说明

    为了保证安装的组件和订阅相匹配,红帽企业 Linux 5 需要输入一个安装号.它被用来配置安装程序来提供正确的软件包.安装号码包含在你的订阅里. 如果您没有输入安装号码,只有核心服务器或 Deskto ...

  6. Android系统级技巧合集

    Android系统级技巧合集(随时更新) #转载请注明来源# 1.高通骁龙系列查看CPU体质等级 CPU体质,即为CPU在工作频率下的电压.同一批次的CPU体质各有不同,体质越高,代表该颗CPU可在更 ...

  7. powerDesigner的name和comment转化

    name2comment.vbs '****************************************************************************** '* ...

  8. codeforces 235 B lets play osu!

    cf235B 一道有意思的题.(据说是美少女(伪)计算机科学家出的,hh) 根据题目要求,就是求ni^2的和. 而n^2=n*(n-1)+n; n*(n-1)=C(n,2)*2: 所以∑ai^2=∑a ...

  9. JavaScript操作数组。

    1.shift:删除原数组第一项,并返回删除元素的值,原数组为空则返回undefined. 2.unshift:将参数添加到原数组开头,并返回数组的长度. 3.pop:删除原数组最后一项,并返回删除元 ...

  10. 文件默认权限umask掩码

    umask命令 作用:用于显示.设置文件的缺省权限 格式:umask   [-S] -S表示以rwx形式显示新建文件缺省权限 系统的默认掩码是0022 文件创建时的默认权限 = 0666 - umas ...