- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章ASP.NET实现上传Excel功能由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
这几天正好用到上传Excel,并根据Excel中的数据做相应的处理,故整理以备用.
用到的资源:
(1)NOPI 2.2.0.0 可自己官网下载,也可点击:http://pan.baidu.com/s/1b1EMdg 。
(2)用到一些常见处理文件的公共方法类,可以添加到项目中:http://pan.baidu.com/s/1bJpHuQ 。
如过上述连接因故无法使用,可在评论留下邮箱,我打包发送过去,如有更好的建议,欢迎指导.
后台的提示方法ShowMsgHelper,根据自己的改写即可.
前台代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
<!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
>导入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
=
"导入"
OnClick
=
"ImpClick"
/>
</
div
>
</
form
>
</
body
>
</
html
>
|
后台代码; 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
|
protected
void
ImpClick(
object
sender, EventArgs e)
{
try
{
#region 校验
var fileName =
this
.FileUpload1.FileName;
if
(
string
.IsNullOrWhiteSpace(fileName))
{
//提示信息
ShowMsgHelper.Alert(
"请选择上传Excel文件"
);
return
;
}
//获取上传文件扩展名称
if
(!(fileName.IndexOf(
".xlsx"
) > 0 || fileName.IndexOf(
".xls"
) > 0))
{
ShowMsgHelper.Alert(
"上传文件格式不正确,请核对!"
);
return
;
}
#endregion
#region 将Excel文件上传到服务器上临时文件夹中
//临时文件夹,根目录下/Upload/tmp/,根据自己配置选择
string
path = Server.MapPath(
"~/"
) +
"Upload\\tmp\\"
;
string
retStr=UploadHelper.FileUpload(path,
this
.FileUpload1);
if
(!retStr.Equals(
"上传成功"
)) {
ShowMsgHelper.Alert(retStr);
return
;
}
#endregion
#region 读取Excel文件第一个表获取内容并转换成DataTable,删除临时文件,也可以自己加时间戳,维护处理
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();
//删除临时文件
DirFileHelper.DeleteFile(
"Upload\\tmp\\"
+ fileName);
#endregion
}
catch
(Exception ex) {
throw
ex;
}
}
/// <summary>
/// 将excel导入到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);
//读取第一个sheet,当然也可以循环读取每个sheet
dataTable =
new
DataTable();
if
(sheet !=
null
)
{
int
rowCount = sheet.LastRowNum;
//总行数
if
(rowCount > 0)
{
IRow firstRow = sheet.GetRow(0);
//第一行
int
cellCount = firstRow.LastCellNum;
//列数
//构建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;
//对时间格式(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
;
}
}
|
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持我! 。
原文链接:http://www.cnblogs.com/MichaelWillLee/p/6633674.html 。
最后此篇关于ASP.NET实现上传Excel功能的文章就讲到这里了,如果你想了解更多关于ASP.NET实现上传Excel功能的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我试图对 ASP.Net MVC 有一个高层次的理解,我开始意识到它看起来很像原始的 ASP 脚本。过去,我们将“模型”/业务逻辑代码组织到 VBScript 类或 VB COM 组件中。 当然,现在
我已经搜索了一段时间,但似乎找不到答案。 我想在我的旋转木马中显示一个计数器,左边是当前项目(工作),左边是项目总数。 我的代码:
. 最佳答案 Scott Gu 称这些为代码块。这就是我的看法。 http://weblogs.asp.net/scottgu/archive/2010/04/06/new-lt-gt-syntax
我有一个使用 Visual Studio 2010/.net 4/VB 制作的网站。 我真的很喜欢我发现的 FAQ 系统的布局,因为它很简单,但它是经典的 asp。所以,显然,我不能包括我的母版页布局
好吧,对于你们许多人来说,这个问题可能有一个非常明显的答案,但它让我难住了。 我有一个 asp.net Web 表单,上面有两个控件(嗯,不止这两个,但我们将重点关注这些) - 第一个是 asp:dr
当我将 ASP.NET 复选框控件设置为 asp.net 更新面板的异步回发触发器时,EventName 属性是什么? 最佳答案 我相信它是 CheckedChanged。 关于asp.net - a
我有一个用经典 asp 编写的(巨大的)网站。现在我必须切换到 vb.net (razor)。有没有办法将这两个结合起来直到切换完成? 有没有办法让应用程序与经典的 asp 和 vb.net 一起工作
I am creating a products page, where the user selects an option in a radiobuttonlist for example, an
我最近将一个经典的 ASP 应用程序转换为 ASP.NET 3.5,但我觉得我的经典 ASP 版本要快一些(我不知道可能买家会后悔)。 所以你们能帮我解决这个问题吗,让我知道哪个更快,asp、asp.
从本周开始,我被要求开始学习如何使用 ASP 开发网站。我通过 XNA 对 C# 有一定的经验,所以这部分对我来说并不是什么麻烦。 我一直在关注Music Store Tutorial这需要我设置一个
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我想将一些表单变量发布到经典 ASP 页面中。我不想改变经典的 ASP 页面,因为需要完成大量的工作,以及消耗它们的页面数量。 经典的 ASP 页面需要将表单变量 Username 和 Userpas
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
在某种程度上,这可能是一个异端问题。我们有一个大型站点,其中许多页面仍在ASP中。通常,并没有真正动态的,而是包括(通过SSI或Server.Execute)定期重新生成的HTML块。看起来好像是一个
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我有一个遗留的 ASP 应用程序——在不久的某个时候——需要迁移到 ASP.Net 2.0(以与也在 2.0 中的其他应用程序兼容)。 对于这类事情是否有最佳实践,即作为第一步将当前 html、vbs
我目前在一家公司工作,该公司使用 ASP.NET Webforms 和旧 ASP 页面的组合进行 Web 开发。这对于他们当前的项目来说效果很好,但我想说服/建议他们切换到 ASP.NET MVC,因
我有一个经典的 asp 应用程序。我想将该页面的竞赛表格发布到 Asp.Net 表格。原因是我想在进入数据库之前使用我在 Asp.Net 页面中内置的大量逻辑进行验证,而我对 asp 不太了解。更不用
我知道在 ASP.NET MVC 中,您可以拥有移动 View 并执行类似 Index.mobile.cshtml 的操作。和 _Layout.mobile.cshtml并且服务器知道将这些 View
我需要从一些服务器端 c#.net 代码中调用经典 asp 页面上的 VBscript 函数 - 有谁知道一种干净的方法来做到这一点?在 .net 中重写函数不是一种选择。 我会再解释一下这个问题..
我是一名优秀的程序员,十分优秀!