热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

XML格式导出Excel

下面介绍一种导出Excel的方法:此方法不需要在服务器上安装Excel,采用生成xml以excel方式输出到客户端,可能需要客户机安装excel,所以也不会有乱七八糟的权限设定,和

下面介绍一种导出Excel的方法:

此方法不需要在服务器上安装Excel,采用生成xmlexcel方式输出到客户端,可能需要客户机安装excel所以也不会有乱七八糟的权限设定,和莫名其妙的版本问题。而且此种方法比第二种更快试了下10W条数据(20列)不到10秒(小白pc)。

 

技术分享技术分享

protected void Btn_Up(object sender, EventArgs e)
{
Response.Clear();
Response.Buffer
= true;
Response.AppendHeader(
"Content-Disposition", "attachment;filename=" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls");
Response.ContentEncoding
= System.Text.Encoding.UTF8;
Response.ContentType
= "application/vnd.ms-excel";
this.EnableViewState = false; Hashtable ht = new Hashtable();
try
{
ht[
"PayAcc"] = payeeaccno.Value;
ht[
"BgDate"] = rzbDate.Value.Replace("-", "");
ht[
"EdDate"] = rzEDate.Value.Replace("-", "");
ht[
"BizBrid"] = bizBrandid;
}
catch (Exception)
{
throw;
}
WithholdingQueryBll wiBill
= new WithholdingQueryBll();//数据操作类
int count = 0;
DataTable qdp
= wiBill.QuerDeductPayee(ht, true, out count);//查询数据,返回DataTable
CreateExcel(qdp, "", "xls");
}
public void CreateExcel(System.Data.DataTable dt, String TableTitle, string fileName)
{
//1) 文本:vnd.ms-excel.numberformat:@
//2) 日期:vnd.ms-excel.numberformat:yyyy/mm/dd
//3) 数字:vnd.ms-excel.numberformat:#,##0.00
//4) 货币:vnd.ms-excel.numberformat:¥#,##0.00
//5) 百分比:vnd.ms-excel.numberformat: #0.00%
StringBuilder strb = new StringBuilder();
DataRow[] myRow
= dt.Select();//可以类似dt.Select("id>10")之形式达到数据筛选目的
strb.Append(" ");
strb.Append(
"xmlns:x=\"urn:schemas-microsoft-com:office:excel\"");
strb.Append(
"xmlns=\" strb.Append(\" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" Sheet1 ");
strb.Append(
" ");
strb.Append(
" 285 ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" 3 ");
strb.Append(
" 1 ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" False ");
strb.Append(
" False ");
strb.Append(
" False ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" 6750 ");
strb.Append(
" 10620 ");
strb.Append(
" 480 ");
strb.Append(
" 75 ");
strb.Append(
" False ");
strb.Append(
" False ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
"");
strb.Append(
" ");
//strb.Append("

");
//strb.Append(" ");
//strb.Append(" ");
//strb.Append(" ");
strb.Append("
");
//strb.Append(TableTitle);
//strb.Append("
");
//写列标题
strb.Append(" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
//strb.Append(" ");
//strb.Append(" ");
strb.Append(" ");
//根据查询出来的字段遍历数据
foreach (DataRow row in myRow)
{
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
strb.Append(
" ");
//strb.Append(" ");
//strb.Append(" ");
strb.Append(" ");
}
strb.Append(
"
" + "交易日期" + " " + "交易时间" + " " + "银行流水号" + " " + "发起方(第三方)流水号" + " " + "收款人账号" + " " + "收款人名称" + " " + "付款人账号" + " " + "付款人名称" + " " + "付款人开户行" + " " + "交易金额" + " " + "交易标志" + " " + "结果信息" + " " + "付款人户名" + " " + "成功/失败原因" + "
" + row["TRANDATE"].ToString() + " " + row["TRANTIME"].ToString() + " " + row["TRANSEQNO"].ToString() + " " + row["THSEQNO"].ToString() + " " + row["PAYEENO"].ToString() + " " + row["PAYEENAME"].ToString() + " " + row["PAYERNO"].ToString() + " " + row["PAYERNAME"].ToString() + " " + row["PAYERBANK"].ToString() + " " + row["TRANAMT"].ToString() + " " + row["TRANSTAT"].ToString() + " " + row["REMSG"].ToString() + " " + row["PAYER_NAME"].ToString() + " " + row["RET_MSG"].ToString() + "
");
strb.Append(
" ");
Response.Clear();
Response.Buffer
= true;
Response.Charset
= "GB2312";
//Response.AppendHeader("Content-Disposition", "attachment;filename=" + fileName);
Response.COntentEncoding= System.Text.Encoding.GetEncoding("GB2312");
//设置输出流为简体中文
Response.COntentType= "application/ms-excel";
//设置输出文件类型为excel文件。
this.EnableViewState = false;
Response.Write(strb);
Response.End();
}


View Code

 

 

 


推荐阅读
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 本文内容为asp.net微信公众平台开发的目录汇总,包括数据库设计、多层架构框架搭建和入口实现、微信消息封装及反射赋值、关注事件、用户记录、回复文本消息、图文消息、服务搭建(接入)、自定义菜单等。同时提供了示例代码和相关的后台管理功能。内容涵盖了多个方面,适合综合运用。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文介绍了指针的概念以及在函数调用时使用指针作为参数的情况。指针存放的是变量的地址,通过指针可以修改指针所指的变量的值。然而,如果想要修改指针的指向,就需要使用指针的引用。文章还通过一个简单的示例代码解释了指针的引用的使用方法,并思考了在修改指针的指向后,取指针的输出结果。 ... [详细]
  • 在project.properties添加#Projecttarget.targetandroid-19android.library.reference.1..Sliding ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
author-avatar
老毛毛
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有