ASP.NET實(shí)現(xiàn)上傳Excel功能
這幾天正好用到上傳Excel,并根據(jù)Excel中的數(shù)據(jù)做相應(yīng)的處理,故整理以備用。
用到的資源:
(1)NOPI 2.2.0.0 可自己官網(wǎng)下載,也可點(diǎn)擊:http://pan.baidu.com/s/1b1EMdg
(2)用到一些常見處理文件的公共方法類,可以添加到項(xiàng)目中:http://pan.baidu.com/s/1bJpHuQ
如過上述連接因故無法使用,可在評論留下郵箱,我打包發(fā)送過去,如有更好的建議,歡迎指導(dǎo)。
后臺(tái)的提示方法ShowMsgHelper,根據(jù)自己的改寫即可。
前臺(tái)代碼:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>導(dǎo)入EXCEL,生成DataTable</title>
<script src="../../Themes/Scripts/jquery-1.8.2.min.js"></script>
<link href="/Themes/Styles/Site.css" rel="external nofollow" rel="stylesheet" type="text/css" />
<script src="/Themes/Scripts/FunctionJS.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function () {
$("#Import").click(function () {
var filename = $("#FileUpload1").val();
if (filename == '') {
alert('請選擇上傳的EXCEL文件');
return false;
}
else {
var exec = (/[.]/.exec(filename)) ? /[^.]+$/.exec(filename.toLowerCase()) : '';
if (!(exec == "xlsx" || exec == "xls")) {
alert("文件格式不對,請上傳Excel文件!");
return false;
}
}
return true;
});
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:FileUpload ID="FileUpload1" runat="server" /><asp:Button ID="Import" runat="server" Text="導(dǎo)入" OnClick="ImpClick" />
</div>
</form>
</body>
</html>
后臺(tái)代碼;
protected void ImpClick(object sender, EventArgs e)
{
try
{
#region 校驗(yàn)
var fileName = this.FileUpload1.FileName;
if (string.IsNullOrWhiteSpace(fileName))
{
//提示信息
ShowMsgHelper.Alert("請選擇上傳Excel文件");
return;
}
//獲取上傳文件擴(kuò)展名稱
if (!(fileName.IndexOf(".xlsx") > 0 || fileName.IndexOf(".xls") > 0))
{
ShowMsgHelper.Alert("上傳文件格式不正確,請核對!");
return;
}
#endregion
#region 將Excel文件上傳到服務(wù)器上臨時(shí)文件夾中
//臨時(shí)文件夾,根目錄下/Upload/tmp/,根據(jù)自己配置選擇
string path = Server.MapPath("~/") + "Upload\\tmp\\";
string retStr=UploadHelper.FileUpload(path, this.FileUpload1);
if (!retStr.Equals("上傳成功")) {
ShowMsgHelper.Alert(retStr);
return;
}
#endregion
#region 讀取Excel文件第一個(gè)表獲取內(nèi)容并轉(zhuǎn)換成DataTable,刪除臨時(shí)文件,也可以自己加時(shí)間戳,維護(hù)處理
DataTable dt = this.ExcelToDataTable(path + this.FileUpload1.FileName, true);
if (dt == null) {
ShowMsgHelper.Alert_Error("獲取失敗");
return;
}
//示例:獲取dt中的值
string test = dt.Rows[0]["name"].ToString();
string test2 = dt.Rows[1]["class"].ToString();
//刪除臨時(shí)文件
DirFileHelper.DeleteFile("Upload\\tmp\\" + fileName);
#endregion
}
catch (Exception ex) {
throw ex;
}
}
/// <summary>
/// 將excel導(dǎo)入到datatable
/// </summary>
/// <param name="filePath">excel路徑</param>
/// <param name="isColumnName">第一行是否是列名</param>
/// <returns>返回datatable</returns>
public DataTable ExcelToDataTable(string filePath, bool isColumnName)
{
DataTable dataTable = null;
FileStream fs = null;
DataColumn column = null;
DataRow dataRow = null;
IWorkbook workbook = null;
ISheet sheet = null;
IRow row = null;
ICell cell = null;
int startRow = 0;
try
{
using (fs = File.OpenRead(filePath))
{
// 2007版本
if (filePath.IndexOf(".xlsx") > 0)
workbook = new XSSFWorkbook(fs);
// 2003版本
else if (filePath.IndexOf(".xls") > 0)
workbook = new HSSFWorkbook(fs);
if (workbook != null)
{
sheet = workbook.GetSheetAt(0);//讀取第一個(gè)sheet,當(dāng)然也可以循環(huán)讀取每個(gè)sheet
dataTable = new DataTable();
if (sheet != null)
{
int rowCount = sheet.LastRowNum;//總行數(shù)
if (rowCount > 0)
{
IRow firstRow = sheet.GetRow(0);//第一行
int cellCount = firstRow.LastCellNum;//列數(shù)
//構(gòu)建datatable的列
if (isColumnName)
{
startRow = 1;//如果第一行是列名,則從第二行開始讀取
for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
{
cell = firstRow.GetCell(i);
if (cell != null)
{
if (cell.StringCellValue != null)
{
column = new DataColumn(cell.StringCellValue);
dataTable.Columns.Add(column);
}
}
}
}
else
{
for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
{
column = new DataColumn("column" + (i + 1));
dataTable.Columns.Add(column);
}
}
//填充行
for (int i = startRow; i <= rowCount; ++i)
{
row = sheet.GetRow(i);
if (row == null) continue;
dataRow = dataTable.NewRow();
for (int j = row.FirstCellNum; j < cellCount; ++j)
{
cell = row.GetCell(j);
if (cell == null)
{
dataRow[j] = "";
}
else
{
//CellType(Unknown = -1,Numeric = 0,String = 1,Formula = 2,Blank = 3,Boolean = 4,Error = 5,)
switch (cell.CellType)
{
case CellType.Blank:
dataRow[j] = "";
break;
case CellType.Numeric:
short format = cell.CellStyle.DataFormat;
//對時(shí)間格式(2015.12.5、2015/12/5、2015-12-5等)的處理
if (format == 14 || format == 31 || format == 57 || format == 58)
dataRow[j] = cell.DateCellValue;
else dataRow[j] = cell.NumericCellValue;
break;
case CellType.String:
dataRow[j] = cell.StringCellValue;
break;
}
}
}
dataTable.Rows.Add(dataRow);
}
}
}
}
}
return dataTable;
}
catch (Exception)
{
if (fs != null)
{
fs.Close();
}
return null;
}
}
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
jQuery Data Linking 對象與對象之間屬性的關(guān)聯(lián)
ASP.NET團(tuán)隊(duì)最近還向jQuery社區(qū)提交了被稱為data linking的技術(shù),Data Linking可以幫助你實(shí)現(xiàn)對象與對象之間屬性的關(guān)聯(lián)——當(dāng)其中一方發(fā)生改變時(shí)另一方也隨之改變。2010-12-12
菜渣開源一個(gè)基于?EMIT?的?AOP?庫(.NET?Core)的方法
CZGL.AOP?是?基于?EMIT?編寫的?一個(gè)簡單輕量的AOP框架,支持非侵入式代理,支持.NET?Core/ASP.NET?Core,以及支持多種依賴注入框架,本文介紹菜渣開源一個(gè)基于?EMIT?的?AOP?庫(.NET?Core)的相關(guān)知識(shí),感興趣的朋友一起看看吧2024-06-06
asp.net點(diǎn)擊 查看更多 實(shí)現(xiàn)無刷新加載的實(shí)現(xiàn)代碼
asp.net點(diǎn)擊 查看更多 實(shí)現(xiàn)無刷新加載的實(shí)現(xiàn)代碼,需要的朋友可以參考下2012-06-06
asp.net 驗(yàn)證碼的簡單制作(vb.net+C#)
asp.net中實(shí)現(xiàn)簡單驗(yàn)證碼的方法,需要的朋友可以參考下2012-05-05
解決.net framework 4.0環(huán)境下遇到版本不同編譯不通過的方法詳解
本篇文章是對.net framework 4.0環(huán)境下遇到版本不同編譯不通過的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
Web API身份認(rèn)證解決方案之Basic基礎(chǔ)認(rèn)證
本文詳細(xì)講解了Web API身份認(rèn)證解決方案之Basic基礎(chǔ)認(rèn)證,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
淺談.net core 注入中的三種模式:Singleton、Scoped 和 Transient
這篇文章主要介紹了淺談.net core 注入中的三種模式:Singleton、Scoped 和 Transient,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-04-04

