Excel文件数据保存到SQL中
1.获取DataTable
/// <summary>
/// 查询Excel文件中的数据
/// </summary>
/// <param name="strPath">文件路径</param>
/// <param name="sheetName">工作表名</param>
/// <returns>DataTable</returns>
public DataTable getExcel(string strPath,string sheetName)
{
string mystring = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source = '" + strPath + "';Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'";
//连接串, HDR=yes 表示excel第一行是标题行,反之表示第一行不是标题行
OleDbConnection cnnxls = new OleDbConnection(mystring);
cnnxls.Open();
OleDbDataAdapter myDa = new OleDbDataAdapter("select * from [" + sheetName + "]", cnnxls);//查询工作表中的数据
DataSet ds = new DataSet();
myDa.Fill(ds, "[" + sheetName + "]");
cnnxls.Close();
DataTable dt = ds.Tables[];
return dt;
}
2.点击按钮函数,将数据存入数据库
/// <summary>
/// 把Excel中的数据保存到sql数据库中
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnSave_Click(object sender, EventArgs e)
{
if (LaValue.Text.Length >)
{
Helper.ExcelHelper eh = new Helper.ExcelHelper();//公共方法类对象,封装Excel操作的方法
DataTable dt = eh.getExcel(LaValue.Text, DropDownList1.Text.ToString());//得到Datatable
DataRow[] dr = dt.Select();//得到
int rowsnum = dt.Rows.Count;//表中数据行数
List<String> lstMsg = new List<string>();//保存失败信息
if (rowsnum == )
{
Page.ClientScript.RegisterStartupScript(this.GetType(), "a", "alert('Excel表为空表,无数据!');", true);
} else
{
String error = "";
for (int i = ; i < dr.Length; i++)//循环插入数据
{
// excel列名不能变
string C_OraName = dr[i]["CompanyName"].ToString();
string C_Town = dr[i]["Town"].ToString();
string C_Trding = dr[i]["Trading"].ToString();
string C_PostCode = dr[i]["PostCode"].ToString();
string C_Phone = dr[i]["Phone"].ToString(); if (String.IsNullOrEmpty(C_OraName))
{
error += "公司名不能为空 ";
}
if (error.Equals("")) //
{
Model.Model_Companey company_model = new Model.Model_Companey();
BLL.BLL_Companey company_bll = new BLL.BLL_Companey();
company_model.C_OraName = C_OraName;
company_model.C_Town = C_Town;
company_model.C_Trding = C_Trding;
company_model.C_Postcode = C_PostCode;
company_model.C_Phone = C_Phone;
// 公司名之前未出现过
if (Helper.SQLHelper.SqlContains(C_OraName, "Companey", "C_OraName") == false)
{
company_bll.Add(company_model);//添加数据
}
else
{
error = C_OraName + "已存在";
lstMsg.Add("未导入成功," + "原因:" + error + "。");//保存错误信息
error = "";
}
}
else
{
}
}
this.txtMessageList.Items.Add("导入完成。");
if (null != lstMsg)
{
this.txtMessageList.Items.Add("共有" + lstMsg.Count() + "条记录未成功。<br /><br />");
foreach (string s in lstMsg)
{
this.txtMessageList.Items.Add(s);
}
}
}
}
}
3.将工作表名放入DropDownList控件中以作选择
/// <summary>
/// 把工作表名绑定到DropDownList控件中
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnup_Click(object sender, EventArgs e)
{
if (FileUpload1.HasFile)
{
string ext = System.IO.Path.GetExtension(FileUpload1.FileName);//获取文件后缀
if (ext.ToLower() != ".xls" && ext.ToLower() != ".xlsx")
{
Page.ClientScript.RegisterStartupScript(this.GetType(), "a", "alert('请选择一个Excel文件!');", true);
return;
}
HttpFileCollection files = HttpContext.Current.Request.Files;//获取页面上所有的FileUpload控件
string tmp = files[].FileName;
string savePath = "e:/test/" + DateTime.Now.ToString("yymmdd") + ".xls";//保存路径
LaValue.Text = savePath; //保存路径到一个不可见的Label控件中
FileUpload1.SaveAs(savePath);//保存文件
DropdownListBind(savePath);//绑定DropDownList
}
}
4.绑定DropDownList函数
/// <summary>
/// 绑定DropDownList
/// </summary>
/// <param name="savePath">路径</param>
protected void DropdownListBind(string savePath)
{
string mystring = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source = '" + savePath + "';Extended Properties='Excel 8.0;HDR=Yes;IMEX=1;'";//连接Excel串
OleDbConnection cnnxls = new OleDbConnection(mystring);//创建连接
cnnxls.Open();
DataSet ds = new DataSet();
DataTable dt = cnnxls.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });//获取工作表名
DropDownList1.DataSource = dt;
foreach (DataRow dr in dt.Rows)
{
DropDownList1.Items.Add((String)dr["TABLE_NAME"]);//向控件中添加工作表名
}
cnnxls.Close();
}
Excel文件数据保存到SQL中的更多相关文章
- 1.scrapy爬取的数据保存到es中
先建立es的mapping,也就是建立在es中建立一个空的Index,代码如下:执行后就会在es建lagou 这个index. from datetime import datetime fr ...
- 将爬取的数据保存到mysql中
为了把数据保存到mysql费了很多周折,早上再来折腾,终于折腾好了 安装数据库 1.pip install pymysql(根据版本来装) 2.创建数据 打开终端 键入mysql -u root -p ...
- c# 抓取和解析网页,并将table数据保存到datatable中(其他格式也可以,自己去修改)
使用HtmlAgilityPack 基础请参考这篇博客:https://www.cnblogs.com/fishyues/p/10232822.html 下面是根据抓取的页面string 来解析并保存 ...
- Redis使用场景一,查询出的数据保存到Redis中,下次查询的时候直接从Redis中拿到数据。不用和数据库进行交互。
maven使用: <!--redis jar包--> <dependency> <groupId>redis.clients</groupId> < ...
- vue下载和上传excle数据文件,解析excel文件数据并存在数据库中
下载: VUE: window.open("xxxx/downloadOldTaskDataFile.do_", "_blank"); JAVA: /** * ...
- 将 excel文件数据导入MySQL数据库中
第一步:先将Excel文件另存为文本文件(制表符分割) 第二步:将生成的txt文件另存,并修改编码格式utf8; 第三步:将文件放到指定位置,或自己想要的位置: G:\city.txt 第四步:避免创 ...
- Python将数据保存到CSV中
#coding:utf-8import csv headers = ['ID','UserName','Password','Age','Country'] rows = [(1001,'qiye', ...
- Python爬虫数据保存到MongoDB中
MongoDB是一款由C++语言编写的非关系型数据库,是一个基于分布式文件存储的开源数据库系统,其内容存储方式类似于JSON对象,它的字段值可以是其它文档或数组,但其数据类型只能是String文本型. ...
- 在scrapy中将数据保存到mongodb中
利用item pipeline可以实现将数据存入数据库的操作,可以创建一个关于数据库的item pipeline 需要在类属性中定义两个常量 DB_URL:数据库的URL地址 DB_NAME:数据库的 ...
随机推荐
- 『电脑技巧』浅谈Win7的文件共享设置
随着移动存储设备的普及,很少有小伙伴喜欢使用局域网“文件共享”这一捷径了 而且自从XP之后,Windows系列主机共享设置貌似比较麻烦 虽然事实并不是看上去那样(Win7也很Easy的说 = =) 现 ...
- [翻译]只为图片使用IMG标签(Use IMG tags only for Images)
原文地址:Use IMG tags only for Images 首先,补充一些背景知识. web开发人员经常通过在主页预加载(预缓存)将来的页面所用到的一些资源的方式来优化网站的性能.常用的手段是 ...
- ASP超级网店V2.5一注入漏洞
Title:ASP超级网店V2.5一注入漏洞 --2011-10-30 17:59 ASP超级网店V2.5 这个系统,有很多地方可以注入 http://www.xxxxxx.com/admin/pi ...
- PHP Java
http://my.oschina.net/lajp/blog/5121 http://blog.163.com/lijianwei_123/blog/static/18489289120115244 ...
- 如何在tomcat启动的时候运行一个Java类
设置个Listener就好了,在web.xml中指定描述. web.xml其实就是tomcat启动的时候会读取的一个描述文件,比如访问服务器的时候首页等都可以在里面指定,有相应的tag.这里有解释:h ...
- Linux系统编程(28)——线程间同步
多个线程同时访问共享数据时可能会冲突,这跟前面讲信号时所说的可重入性是同样的问题.比如两个线程都要把某个全局变量增加1,这个操作在某平台需要三条指令完成: 从内存读变量值到寄存器 寄存器的值加1 将寄 ...
- System.Drawing.Image.Save(Savepath),保存为jpg格式,参数错误,文件0kb解决办法
问题场景:asp.net给图片添加文字水印保存为jpg格式时出现标题所描述错误(图片为.jpg格式): 简单验证:用本机的画图程序打开,然后保存为jpg格式会出现警告框"画图程序不能存储该文 ...
- HDU_2035——求A^B的最后三位数
Problem Description 求A^B的最后三位数表示的整数.说明:A^B的含义是“A的B次方” Input 输入数据包含多个测试实例,每个实例占一行,由两个正整数A和B组成(1< ...
- RHEL修改主机名和IP
1, 修改主机名 vi /etc/sysconfig/network NETWORKING=yes HOSTNAME=NEWHOSTNAME #修改该值作为主机名,如:NEWPC ...
- JS-事件处理
1.一个简单的单击事件: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...