- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章asp.net实现导出DataTable数据到Word或者Excel的方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
本文实例讲述了asp.net实现导出DataTable数据到Word或者Excel的方法。分享给大家供大家参考,具体如下:
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
|
/// <summary>< xmlnamespace prefix ="o" ns ="urn:schemas-microsoft-com:office:office" />
/// 导出DataTable数据到Word或者Excel
/// </summary>
/// <param name="pPage">Page指令</param>
/// <param name="dt">DataTable数据表</param>
/// <param name="str_ExportTitle">导出Word或者Excel表格的名字</param>
/// <param name="str_ExportContentTitle">导出Word或者Excel表格中内容的标题</param>
/// <param name="str_ExportMan">导出Word或者Excel的人</param>
/// <param name="str_ExportType">导出类型(w:Word,e:Excel)</param>
public
bool
DataTableToExcel(Page pPage, DataTable dt,
string
str_ExportTitle,
string
str_ExportContentTitle,
string
str_ExportMan,
string
str_ExportType)
{
bool
bl_Result =
false
;
string
str_ExportTypeName =
"word"
;
//导出类型
string
str_ExportFormat =
".doc"
;
//导出类型的格式
if
(str_ExportType.Equals(
"e"
))
{
str_ExportTypeName =
"excel"
;
str_ExportFormat =
".xls"
;
}
HttpResponse response = pPage.Response;
if
(dt.Rows.Count > 0)
{
response.ContentEncoding = System.Text.Encoding.GetEncoding(
"GB2312"
);
response.ContentType =
"application/ms-"
+ str_ExportTypeName;
response.AppendHeader(
"Content-Disposition"
,
"attachment;filename="
+ HttpUtility.UrlEncode(str_ExportTitle, System.Text.Encoding.UTF8).ToString()
//该段需加,否则会出现中文乱码
+ str_ExportFormat);
//获取DataTable的总列数
int
i_ColumnCount = dt.Columns.Count;
//定义变量存储DataTable内容
System.Text.StringBuilder builder =
new
System.Text.StringBuilder();
builder.Append(
"<html><head>\n"
);
builder.Append(
"<meta http-equiv=\"Content-Language\" content=\"zh-cn\">\n"
);
builder.Append(
"<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\">\n"
);
builder.Append(
"</head>\n"
);
builder.Append(
"<table border='1' style='width:auto;'>"
);
if
(!
string
.IsNullOrEmpty(str_ExportContentTitle))
{
builder.Append(
string
.Concat(
new
object
[] {
"<tr><td colspan="
, (i_ColumnCount + 1),
" style='border:1px #7f9db9 solid;font-size:18px;font-weight:bold;'>"
,
str_ExportContentTitle,
"</td></tr>"
}));
}
builder.Append(
"<tr><td colspan="
+ (i_ColumnCount + 1) +
" valign='middle' style='border:1px #7f9db9 solid;height:24px;'>"
);
builder.Append(
"导出人:【"
+ str_ExportMan +
"】,导出时间:【"
+ DateTime.Now.ToString(
"yyyy-MM-dd hh:mm:ss"
) +
"】</td></tr>"
);
builder.Append(
"<tr>\n"
);
builder.Append(
"<td style='border:1px #7f9db9 solid;bgcolor:#dee7f1;font-weight:bold;width:auto;'>序号</td>\n"
);
for
(
int
i = 0; i < i_ColumnCount; i++)
{
if
(dt.Columns[i].Caption.ToString().ToLower() !=
"id"
)
{
builder.Append(
"<td style='border:1px #7f9db9 solid;bgcolor:#dee7f1;width:auto;' align='center'><b>"
+ dt.Columns[i].Caption.ToString() +
"</b></td>\n"
);
}
}
#region 此处没有在导出的数据列的最前面加一列(序号列)
//此处没有在导出的数据列的最前面加一列(序号列)
//foreach (DataRow row in dt.Rows)
//{
// builder.Append("<tr>");
// for (int j = 0; j < i_ColumnCount; j++)
// {
// if (dt.Columns[j].Caption.ToString().ToLower() != "id")
// {
// builder.Append("<td style='border:1px #7f9db9 solid;vnd.ms-excel.numberformat:@'>" + row[j].ToString() + "</td>");
// }
// }
// builder.Append("</tr>\n");
//}
#endregion
#region 在导出的数据列的最前面加了一序号列(注意:非DataTable数据的序号)
//在导出的数据列的最前面加了一序号列(注意:非DataTable数据的序号)
for
(
int
m = 0; m < dt.Rows.Count; m++)
{
builder.Append(
"<tr>"
);
for
(
int
j = 0; j < i_ColumnCount; j++)
{
if
(dt.Columns[j].Caption.ToString().ToLower() !=
"id"
)
{
if
(j == 0)
{
builder.Append(
"<td style='border:1px #7f9db9 solid;width:auto;' align='center'>"
+ (m + 1) +
"</td>"
);
}
if
(j > 0)
{
builder.Append(
"<td style='border:1px #7f9db9 solid;width:auto;vnd.ms-excel.numberformat:@' align='left'>"
+ dt.Rows[m][j - 1].ToString() +
"</td>"
);
}
if
(j == dt.Columns.Count - 1)
{
builder.Append(
"<td style='border:1px #7f9db9 solid;width:auto;vnd.ms-excel.numberformat:@' align='left'>"
+ dt.Rows[m][j].ToString() +
"</td>"
);
}
}
}
builder.Append(
"</tr>\n"
);
}
#endregion
builder.Append(
"<tr><td colspan="
+ (i_ColumnCount + 1) +
" valign='middle' style='border:1px #7f9db9 solid;height:24px;' align='left'>"
);
builder.Append(
"合计:共【<font color='red'><b>"
+ dt.Rows.Count +
"</b></font>】条记录</td></tr>"
);
builder.Append(
"<tr>\n"
);
builder.Append(
"</table>"
);
response.Write(builder.ToString());
response.End();
bl_Result =
true
;
}
return
bl_Result;
}
|
。
希望本文所述对大家asp.net程序设计有所帮助.
最后此篇关于asp.net实现导出DataTable数据到Word或者Excel的方法的文章就讲到这里了,如果你想了解更多关于asp.net实现导出DataTable数据到Word或者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 中重写函数不是一种选择。 我会再解释一下这个问题..
我是一名优秀的程序员,十分优秀!