代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Asp.Net
】
上传Excel 表内容到数据库用GridView显示出来
作者:
/ 发布于
2014/10/21
/
796
using System.IO; //判断是否上传文件,若上传,上传的文件是否存在、格式是否正确。fileupload1为FileUpload 控件ID protected bool IsFileupload(FileUpload fileupload1, out string message, out string filepath) { if (fileupload1.HasFile) //判断该控件是否包含文件 { string fullfilename = fileupload1.PostedFile.FileName; string filename = fullfilename.Substring(fullfilename.LastIndexOf("\\") + 1); string type = filename.Substring(filename.LastIndexOf('.') + 1); //截取文件名后缀 if (type.ToLower() == "xls") { string basepath = this.Server.MapPath("~\\Temp\\教师信息"); //保存到文件夹 string subpath = basepath + "\\" + DateTime.Now.ToString("yyyyMMddhhmmss") + filename; //修改上传文件名字,避免重复名称 if (!File.Exists(subpath)) { if (!Directory.Exists(Server.MapPath("~\\Temp"))) Directory.CreateDirectory(basepath); if (!Directory.Exists(basepath)) Directory.CreateDirectory(basepath); filepath = subpath; message = ""; return true; } else { message = "您上传的文件已存在,请重命名后再上传!"; filepath = ""; return false; } } else { message = "您上传的文件格式不正确!"; filepath = ""; return false; } } else { message = "您未上传文件或上传的文件为空!"; filepath = ""; return false; } } using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.Collections; //将Excel表中数据转换为DataSet 类型 public static DataSet ExcelToDatatable(string filepath) { HSSFWorkbook hssfworkbook = null; using (FileStream file = new FileStream(filepath, FileMode.Open, FileAccess.Read)) { hssfworkbook = new HSSFWorkbook(file); } NPOI.SS.UserModel.ISheet sheet = hssfworkbook.GetSheetAt(0); IEnumerator rows = sheet.GetRowEnumerator(); DataSet ds = new DataSet(); DataTable dt = new DataTable(); int rowIndex = 1; while (rows.MoveNext()) { NPOI.SS.UserModel.IRow row = (NPOI.HSSF.UserModel.HSSFRow)rows.Current; DataRow dr = null; if (rowIndex == 1) { for (int i = 0; i < row.LastCellNum; i++) { ICell cell = row.GetCell(i); string value; if (cell == null) value = string.Empty; else value = cell.ToString(); dt.Columns.Add(value); } if (dr != null) dt.Rows.Add(dr); } else { for (int i = 0; i < row.LastCellNum; i++) { ICell cell = row.GetCell(i); string value; if (cell == null) value = string.Empty; else value = cell.ToString(); if(dr == null) dr = dt.NewRow(); dr[i] = value; } if (dr != null) dt.Rows.Add(dr); } rowIndex++; } ds.Tables.Add(dt); return ds; } //导入按钮事件 protected void btn_users_Click(object sender, EventArgs e) { string message = ""; string filepath = ""; if (IsFileupload(FU_users, out message, out filepath)) { FU_users.PostedFile.SaveAs(filepath); DataSet ds = NPOITool.ExcelToDatatable(filepath); if (ds != null && ds.Tables.Count > 0) { try { // 数据有效性判断 string error = "";//姓名是否为空\是否重复 List<string> namelist = new List<string>(); for (int i = 0; i < ds.Tables[0].Rows.Count; i++) { DataRow dr = ds.Tables[0].Rows[i]; string name = dr[0].ToString(); if (string.IsNullOrEmpty(name)) { error += (i + 2).ToString() + ","; } if (namelist.Contains(name)) { error += (i + 2).ToString() + ","; } else namelist.Add(name); } if (error == "") { //把数据添加到数据库 } else { error = "以下行数姓名为空或重复:" + error.TrimEnd(',') + "\\n"; ClientScript.RegisterStartupScript(this.GetType(), "alert", "<script language= 'javascript'>alert('" + error + "')</script>"); File.Delete(filepath); } } catch { ClientScript.RegisterStartupScript(this.GetType(), "alert", "<script language= 'javascript'>alert('请按模板要求填写信息。')</script>"); File.Delete(filepath); } } else { ClientScript.RegisterStartupScript(this.GetType(), "alert", "<script language= 'javascript'>alert('文件异常。')</script>"); File.Delete(filepath); } } else { ClientScript.RegisterStartupScript(this.GetType(), "alert", "<script language= 'javascript'>alert('" + message + "')</script>"); } }
试试其它关键字
上传Excel
GridView
同语言下
.
gzip压缩
.
实现http多线程断点续传下载文件
.
实现多线程断点续传下载大文件
.
生成字符串的 CheckSum
.
根据 UserAgent 获取浏览器的类型和版本
.
根据 Agent 判断是否是智能手机
.
隐藏手机号中间四位为*方法
.
合并图片(二维码和其他图片合并)
.
ASP.NET CORE中判断是否移动端打开网页
.
ASP.NET(C#)实现页面计时(定时)自动跳转
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
贡献的其它代码
Label
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3