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)。
后臺的提示方法ShowMsgHelper,根據(jù)自己的改寫即可。
前臺代碼:
<!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>
后臺代碼;
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)文章
ASP.NET Core中修改配置文件后自動(dòng)加載新配置的方法詳解
這篇文章主要給大家介紹了關(guān)于ASP.NET Core中修改配置文件后自動(dòng)加載新配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用ASP.NET Core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
微信公眾平臺開發(fā)之發(fā)送文本消息.Net代碼解析
這篇文章主要為大家詳細(xì)解析了微信公眾平臺開發(fā)之發(fā)送文本消息.Net代碼,感興趣的小伙伴們可以參考一下2016-06-06
DropDownList綁定選擇數(shù)據(jù)報(bào)錯(cuò)提示異常解決方案
DropDownList控件在綁定選擇數(shù)據(jù)時(shí)提示報(bào)錯(cuò)異常詳細(xì)信息為:有一個(gè)無效 SelectedValue,因?yàn)樗辉陧?xiàng)目列表中,應(yīng)該有很多新手朋友們遇到過吧,本文將給予解決方法,感興趣的朋友可以了解下,希望本對你有所幫助2013-01-01
.net core使用FastHttpApi構(gòu)建web聊天室實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于.net core使用FastHttpApi構(gòu)建web聊天室的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-10-10
ASP.NET Session對象保持會(huì)話使用說明
ASP.NET提供了Session對象,從而允許程序員識別、存儲和處理同一個(gè)瀏覽器對象對服務(wù)器上某個(gè)特定網(wǎng)絡(luò)應(yīng)用程序的若干次請求的上下文信息2012-12-12

