Asp.Net异步导入Excel
故事:用户在页面上传一个excel文件,程序把excel里的内容入库。
技术方案:保存文件在服务器,jquey Ajax 异步读取文件中的记录到数据库,在页面实时刷新导入情况
页面前端
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="ImportUsers.aspx.cs" Inherits="Community.WebUI.zsclient.ImportUsers" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript">
function importUserOnce(f, r) {
$.ajax({
url: "ImportUsers.aspx/ImportUserOnce", type: "POST", contentType: "application/json;charset=utf-8", data: "{ 'f': '" + f + "' ,'r':'" + r + "'}", dataType: "json", cache: false,
success: function (msg) {
var m = msg.d.split(',');
var rowNumber = m[0];
var rowCount = m[1];
$("#<%=txtResult.ClientID%>").append(m[2]);
if (rowNumber != rowCount) {
$("#spanMsg").text("正在导入用户,已导入"+rowNumber+"用户,根据用户多少可能需要一段时间,请您耐心等候……");
importUserOnce(f, rowNumber);
}
else {
$("#<%=btnSubmitExcel.ClientID%>").removeAttr("disabled");
$("#spanMsg").text("完成,总用户数"+rowCount);
}
},
error: function (request, err,ex) {
$("#spanMsg").text(err);
$("#<%=btnSubmitExcel.ClientID%>").removeAttr("disabled");
}
})
return;
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div> <table style="margin-left: auto; margin-right: auto;">
<tr>
<th>从Excel导入用户</th>
</tr>
<tr>
<td>
<asp:FileUpload ID="FileUpload1" runat="server" /><asp:Button ID="btnSubmitExcel" runat="server" Text="确定" OnClick="btnSubmitExcel_Click" />
<input runat="server" id="txtFName" type="hidden" />
<span id="spanMsg"></span>
</td>
</tr>
</table>
<div style="width: 800px; height: 600px; margin-left: auto; margin-right: auto;">
<div id="txtResult" runat="server" style="width: 800px; height: 600px; overflow: scroll; border: 1px solid #ccc;">
</div>
</div> </div>
</form>
<script type="text/javascript">
var fvalue = "";
var int = self.setInterval("clock()", 50)
function clock() {
fvalue = $("#<%=txtFName.ClientID%>").val();
if (fvalue != "") {
int = window.clearInterval(int);
importUserOnce(fvalue, 0);
$("#<%=btnSubmitExcel.ClientID%>").attr("disabled", "disabled");
$("#spanMsg").text("正在导入用户,根据用户多少可能需要一段时间,请您耐心等候……");
}
}
</script>
</body>
</html>
后台代码
[WebMethod]
public static string ImportUserOnce(string f, string r)
{
string fileName = AppDomain.CurrentDomain.BaseDirectory + "/zsclient/" + f;
if (!System.IO.File.Exists(fileName))
{
return fileName + "0,0,不存在";
}
int rowIndex = ;
if (!int.TryParse(r, out rowIndex) || rowIndex < )
{
return "0,0,rowIndex格式错误";
} FileStream stream = File.OpenRead(fileName);
IWorkbook workbook;
if (fileName.EndsWith("xls"))
{
workbook = new HSSFWorkbook(stream);//从流内容创建Workbook对象
}
else
{
workbook = new XSSFWorkbook(stream);//从流内容创建Workbook对象
}
ISheet sheet = workbook.GetSheetAt();//获取第一个工作表
int rowCount = sheet.LastRowNum; string strStatus = "";
if (rowIndex <= rowCount)
{ int userNum = ; while (rowIndex < rowCount && userNum < )
{
if (sheet.GetRow(rowIndex).GetCell() == null || sheet.GetRow(rowIndex).GetCell() == null)
{
rowIndex++;
userNum++;
continue;
}
UserInfo objUser = new UserInfo()
{
Username = sheet.GetRow(rowIndex).GetCell().ToString();
Password = sheet.GetRow(rowIndex).GetCell().ToString(), };
UserCreateStatus userCreateStatus = CreateUser(ref objUser);
if (userCreateStatus != UserCreateStatus.Success)
{ switch (userCreateStatus)
{
case UserCreateStatus.InvalidPassword:
strStatus += "用户" + strName + "密码不符合要求,密码长度6-20位\r\n<br/>";
break;
case UserCreateStatus.UserAlreadyRegistered:
strStatus += "用户名" + strName + "已存在\r\n<br/>";
break;
case UserCreateStatus.UsernameAlreadyExists:
strStatus += "用户名" + strName + "已存在\r\n<br/>";
break;
case UserCreateStatus.InvalidUserName:
strStatus += "用户名" + strName + "不符合要求,4-20位字母或数字\r\n<br/>";
break;
default:
strStatus += UserController.GetUserCreateStatus(userCreateStatus);
break;
}
}
else
{
strStatus += strName + "导入成功\r\n<br/>";
}
userNum++;
rowIndex++;
}
}
return rowIndex.ToString() + "," + rowCount.ToString() + "," + strStatus;
}
读取excel文件采用NPOI

using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
提供一个OLEDB方法
private static DataSet GetDataFromExcel(string fileName)
{
string connStr;
if (fileName.EndsWith(".xls"))
connStr = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + fileName + ";" + ";Extended Properties=\"Excel 8.0;HDR=YES;IMEX=1\"";
else
connStr = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + fileName + ";" + ";Extended Properties=\"Excel 12.0;HDR=YES;IMEX=1\""; string sql_F = "Select * FROM [{0}]"; OleDbConnection conn = null;
OleDbDataAdapter da = null;
DataTable dtSheetName = null; DataSet ds = new DataSet();
try
{
// 初始化连接,并打开
conn = new OleDbConnection(connStr);
conn.Open(); // 获取数据源的表定义元数据
string SheetName = "";
dtSheetName = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" }); // 初始化适配器
da = new OleDbDataAdapter();
for (int i = ; i < dtSheetName.Rows.Count; i++)
{
SheetName = (string)dtSheetName.Rows[i]["TABLE_NAME"]; if (SheetName.Contains("$") && !SheetName.Replace("'", "").EndsWith("$"))
{
continue;
} da.SelectCommand = new OleDbCommand(String.Format(sql_F, SheetName), conn);
DataSet dsItem = new DataSet();
da.Fill(dsItem, SheetName); ds.Tables.Add(dsItem.Tables[].Copy());
}
}
catch (Exception ex)
{ }
finally
{
// 关闭连接
if (conn.State == ConnectionState.Open)
{
conn.Close();
da.Dispose();
conn.Dispose();
}
}
return ds;
}
Asp.Net异步导入Excel的更多相关文章
- JavaScript日历控件开发 C# 读取 appconfig文件配置数据库连接字符串,和配置文件 List<T>.ForEach 调用异步方法的意外 ef 增加或者更新的习惯思维 asp.net core导入excel 一个二级联动
JavaScript日历控件开发 概述 在开篇之前,先附上日历的代码地址和演示地址,代码是本文要分析的代码,演示效果是本文要实现的效果代码地址:https://github.com/aspwebc ...
- Asp.Net Core 导入Excel数据到Sqlite数据库并重新导出到Excel
Asp.Net Core 导入Excel数据到Sqlite数据库并重新导出到Excel 在博文"在Asp.Net Core 使用 Sqlite 数据库"中创建了ASP.NET Co ...
- ASP.NET MVC导入excel到数据库
MVC导入excel和webform其实没多大区别,以下为代码: 视图StationImport.cshtml的代码: @{ ViewBag.Title = "StationImport&q ...
- POI异步导入Excel兼容xsl和xlsx
项目架构:spring+struts2+hibernate4+oracle 需求:用户导入excel文件,导入到相应的数据表中,要求提供导入模板,支持xls和xlsx文件 思路分析: 1.提供一个下载 ...
- asp.net core导入excel
接昨天的导出 导入excel内容 对比昨天导出的内容增加了一行实体属性名称作为标题行,这样到转换为实体的时候才能找到对应的属性. 导入代码 public IActionResult InportExc ...
- MVC异步 导入excel文件
View页面 js文件.封装到一个js文件里面 (function ($) { //可以忽略 var defaultSettings = { url: "http://upload.zhtx ...
- ASP.NET MVC 导入Excel文件
一:view部分 <form method="post" enctype="multipart/form-data" action="/Posi ...
- ASP.NET MVC 导入Excel文件(完整版)
View视图部分: <form method="post" enctype="multipart/form-data" action="/Pos ...
- ASP.NET导入Excel到SQL数据库
protected void btnChange_Click(object sender, EventArgs e) { UserInfoClass tClass = (UserInfoClass)S ...
随机推荐
- ASP.NET多个Button的页面,回车执行按钮事件(转)
主要有两种实现方法分别是:JavaScript的方法与Panel的方法 一.JavaScript的方法 ①单输入框(文本框)单按钮的实现方法 以下功能实现:在输入框中输入内容之后,按回车键就执行按钮事 ...
- 彻底删除java*
提示:先备份重要数据 1. 移除所有 Java相关包 (Sun, Oracle, OpenJDK, IcedTea plugins, GIJ): apt-get update apt-cache se ...
- C语言:内存字节对齐详解[转载]
一.什么是对齐,以及为什么要对齐: 1. 现代计算机中内存空间都是按照byte划分的,从理论上讲似乎对任何类型的变量的访问可以从任何地址开始,但实际情况是在访问特定变量的时候经常在特定的内存地址访问, ...
- centos7 firewall 防火墙 命令
为了架设ss在vultr上买了一个日本的vps 用的是centos7的系统 防火墙是 firewall 捣鼓了两天 在这里总结一下. 如果小伙伴也准备在vultr上买vps 在注册是 可以使用这个优 ...
- Cannot find class for bean with name '/hello' defined in ServletContext resource
Cannot find class for bean with name '/hello' defined in ServletContext resource [/WEB-INF/chapter2- ...
- Servlet 实现上传文件以及同时,写入xml格式文件和上传
package com.isoftstone.eply.servlet; import java.io.BufferedReader; import java.io.BufferedWriter; i ...
- 学习mongo系列(一) win/mac安装 解析 连接
一.安装mongo数据库 下载链接https://www.mongodb.org/downloads, 在执行如下命令的时候事先按照目录新建如下的目录:(如果数据库安装在D盘就在D盘的根目录下建)&q ...
- Python脚本开头两行的:#!/usr/bin/python和# -*- coding: utf-8 -*-的作用
#!/usr/bin/Python指定用什么解释器运行脚本以及解释器所在的位置 # -*- coding: utf-8 -*-用来指定文件编码为utf-8的 估计有不少人注意过一些python脚本开头 ...
- HBase之show table
import org.apache.hadoop.hbase.HTableDescriptor; import org.apache.hadoop.hbase.TableName; import or ...
- 最精简的django程序
一.程序框架 1.结构图