excel 在web导入到数据库的操作方法
这个操作的大致步骤是把本地文件存入到服务器端,
然后再读取服务端的文件并且使用NPOI这个第三方的插件去读取文件导入到数据库批量插入
需要注意的是,前端需要使用form包裹type=file的文件标签,并且文件标签需要有name属性,否则后台无法获取,在一个就是form需要含有enctype="multipart/form-data"属性,
对于input过滤其他非excel的文件,可以添加如下属性:accept="application/vnd.ms-excel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
HTML:
<form id="form" class="form-horizontal" enctype="multipart/form-data">
<div class="form-group">
<label for="txt_signInTitleOfDetail">选择文件</label>
<input type="file" name="file" class="form-control" accept="application/vnd.ms-excel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" />
</div>
<input type="button" class="btn btn-primary" value="保存" id="btn_Save">
</form>
JS:
//这里的HTMLFormElement是强制转换的写法,因为是typescript所以不强制转换的话编译不能通过
var myForm = <HTMLFormElement>$('#你的要提交的form的ID')[0];
var formData = new FormData(myForm);//和后台联通让后台接受form的系统类
//获取文件名
var filePath = $('#txt_upload').val();
var fileName = filePath.substring(filePath.lastIndexOf('\\') + 1);
formData.append('fileName', fileName);
$('#waring').text("操作中,请等待");
$.ajax({
url: '/Home/后台的导入方法',
type: 'POST',
cache: false,
data: formData,
processData: false,
contentType: false
}).done(function (res) {
//批量导入后刷新页面
$('#waring').text(res.message);
}).fail(function (res) {
$('#waring').text("导入数据失败");
});
后台:
public JsonResult 你的方法()
{
var httpRequest = HttpContext.Request; string fileName = string.Format("{0}_{1}", DateTime.Now.ToString("yyyyMMddHHmmss"), httpRequest.Form["fileName"].ToString());
//文件夹
string dir = Server.MapPath("~/temp");
if (!Directory.Exists(dir))
{
Directory.CreateDirectory(dir);
} //文件全路径,获取了本地的文件路径
string filePath = Path.Combine(dir, fileName); foreach (string key in httpRequest.Files) // 文件键
{
var postedFile = httpRequest.Files[key]; // 获取文件键对应的文件对象
postedFile.SaveAs(filePath);
}
//// 读取Excel文件,导入数据
ExcelToDB(filePath); return Json(new
{
status = true,
message = "导入成功!"
});
} private void ExcelToDB(string filePath)
{
FileStream fs = null;
IWorkbook workbook = null;
ISheet sheet = null;
IRow row = null;
//ICell cell = null;
int startRow = ;
try
{
using (fs = System.IO.File.OpenRead(filePath))
{
// 2007版本
if (filePath.IndexOf(".xlsx") > )
workbook = new XSSFWorkbook(fs);
// 2003版本
else if (filePath.IndexOf(".xls") > )
workbook = new HSSFWorkbook(fs); if (workbook != null)
{
workbook.MissingCellPolicy = MissingCellPolicy.RETURN_BLANK_AS_NULL;
//sheet = workbook.GetSheetAt(0);//读取第一个sheet,当然也可以循环读取每个sheet
sheet = workbook.GetSheet("Sheet1"); if (sheet != null)
{
int rowCount = sheet.LastRowNum;//总行数
if (rowCount > )
{
IRow firstRow = sheet.GetRow();//第一行
int cellCount = firstRow.LastCellNum;//列数 WriteData(sheet, row, startRow, rowCount);
}
else
{
throw new Exception("无信息");
}
}
else
{
throw new Exception("没有找到Sheet1");
}
}
else
{
throw new Exception("加载Excel失败");
}
} }
catch (Exception ex)
{
if (fs != null)
{
fs.Close();
} throw ex;
}
} /// <summary>
/// 从excel写入登记表
/// </summary>
/// <param name="sheet"></param>
/// <param name="row"></param>
/// <param name="startRow"></param>
/// <param name="rowCount"></param>
/// <param name="isCover"></param>
private void WriteData(ISheet sheet, IRow row, int startRow, int rowCount)
{
List<你的插入类> 你的插入类 = new List<你的插入类>();
string Title = string.Empty;
string Time = string.Empty;
string EndTime = string.Empty;
string Range = string.Empty;
//填充行
for (int i = startRow; i <= rowCount; ++i)
{
row = sheet.GetRow(i);
if (row == null) continue; try
{
//读取一行每个字段值
Title = row.GetCell(, MissingCellPolicy.CREATE_NULL_AS_BLANK).ToString(); //
Time = row.GetCell(, MissingCellPolicy.CREATE_NULL_AS_BLANK).ToString();//
EndTime = row.GetCell(, MissingCellPolicy.CREATE_NULL_AS_BLANK).ToString();//
taskType = ;//
signInRange = row.GetCell(, MissingCellPolicy.CREATE_NULL_AS_BLANK).ToString();// //没有信息,直接跳过
if (string.IsNullOrEmpty(Title) || string.IsNullOrEmpty(Time) || string.IsNullOrEmpty(EndTime))
{
continue;
} info item = new info()
{
读取的行在这里和实体类赋值
}; list.Add(item);
}
catch (Exception ex)
{ }
} //批量插入
Dal.BatchInsert(list);
}
excel 在web导入到数据库的操作方法的更多相关文章
- 把Excel的数据导入到数据库
将Excel作为数据源,将数据导入数据库,是SSIS的一个简单的应用,下图是示例Excel,数据列是code和name 第一部分,Excel中的数据类型是数值类型 1,使用SSDT创建一个packag ...
- Excel表格数据导入Mysql数据库的方法
1.使用Navicat 连接需要导入的数据库. 2.excel 列的名字最好和数据库的名字一致,便于我们直观的查看好理解. 第一步,先创建好表,和准备好对应的excel文件.在Navicat 中选 ...
- java读取excel文件数据导入mysql数据库
这是我来公司的第二周的一个小学习任务,下面是实现过程: 1.建立maven工程(方便管理jar包) 在pom.xml导入 jxl,mysql-connector 依赖 可以在maven仓库搜索 2.建 ...
- Excel表格数据导入MySQL数据库
有时候项目需要将存在表格中的批量数据导入数据库,最近自己正好碰到了,总结一下: 1.将excel表格另存为.csv格式文件,excel本身的.xlsx格式导入时可能会报错,为了避免不必要的格式错误,直 ...
- ASP.NET MVC NPOI导入Excel DataTable批量导入到数据库
使用NPOI导入Excel 首先在MVC项目中导入NPOI 查询NPOI安装,排序依据,选择:最高下载量,选择第一个. 在控制器中创建ExcelController 在Index视图中写入代码: @u ...
- Java版将EXCEL表数据导入到数据库中
1.采用第三方控件JXL实现 try { //实例化一个工作簿对象 Workbook workBook=Workbook.getWorkbook(new File("F://qzlx.xls ...
- C#将Excel数据表导入SQL数据库的两种方法(转)
最近用写个winform程序想用excel 文件导入数据库中,网上寻求办法,找到了这个经过尝试可以使用. 方法一: 实现在c#中可高效的将excel数据导入到sqlserver数据库中,很多人通过循环 ...
- 将excel的数据导入到数据库后都乱码了是怎么回事
将excel内容首先保存成csv格式,然后在MySQL数据库中导入,结果汉字出现了乱码. 解决过程: 1.csv文件以txt形式打开,另存为,选择utf-8编码. 2.数据库,设置,collation ...
- C#将Excel数据表导入SQL数据库的两种方法
最近用写个winform程序想用excel 文件导入数据库中,网上寻求办法,找到了这个经过尝试可以使用. 方法一: 实现在c#中可高效的将excel数据导入到sqlserver数据库中,很多人通过循环 ...
随机推荐
- jdk 自动化脚本
添加没有登录权限 需要理解linux用户,首先登陆的是root用户,拥有所有的权限,但是该权限太大,一般都会分配其他用户使用,并且在部署程序时,需要分配一个没有登录权限的用户,这样改程序不能随意被修改 ...
- 为 “超级大脑”构建支撑能力,腾讯云聚焦AI技术落地
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 5月24日,以"无界数据.无限智能"为主题的2018腾讯"云+未来"峰会AI大数据分论坛在广州拉开帷 ...
- c#,利用WPF的ScaleTransform和TranslateTransform实现图片的缩放效果
一.缩放要求 1.缩放对象在可视区域内,已对象的中心点进行缩放. 2.缩放对象比可视区大,并且对象各边界都在可视区外围,那么已鼠标位置进行缩放. 3.缩放对象比可视区大,但是缩放后某一边界在可视区的对 ...
- Java入门系列-15-封装
为什么要封装 Student stu=new Student(); stu.age=-10; 上面的代码中 age 属性被随意访问,容易产生不合理的赋值 什么是封装 封装:将类的某些信息隐藏在内部,不 ...
- Codeforces 671 A——Recycling Bottles——————【思维题】
Recycling Bottles time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
- HDU 5690——All X——————【快速幂 | 循环节】
All X Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submi ...
- redis操作基本命令
Redis—— Remote Dictionary Server,它是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API,我们 ...
- java设计模式--基础思想总结--抽象类与架构设计思想
抽象类?这个东西我感觉没什么卵用啊,又不能拿来new对象,没有具体的对象的抽象类,有什么实际的意义呢?这是很多刚刚接触java抽象类语法时的第一反应(当然,包括我).确实,很多刚刚接触抽象类这个概念的 ...
- mycat安装
一.简介 在互联网数据大爆炸时代,对数据处理的要求越来越高,很明显单实例数据库已经不能满足需求了,这时候数据库的中间件便应运而生.中间件聚集多实例来提供更强的处理能力,并且隐藏了多实例产生的复杂性.m ...
- 关于request请求的基本获取
1.Request对象的作用是与客户端交互,收集客户端的Form.Cookies.超链接,或者收集服务器端的环境变量. request对象是从客户端向服务器发出请求,包括用户提交的信息以及客户端的 ...