bianwu 哈希表输出到 excel
一、输出到excel
函数:
protected void InputFileTheme(object[] Header,object [] DataFileds,string sql,string filename)
{
SqlDBHandler dbHandler=this.getDBHandler();
string filterStr=",";
string strTemp;
Hashtable hashTable=new Hashtable();
//hashTable.Add("laguage","513");//正文语种
/*hashTable.Add("themetype3","504");//参考地图地域类别
hashTable.Add("themetype4","505");//参考地图形式类别
hashTable.Add("themetype5","508");//基础教材性质类别
hashTable.Add("themetype6","506");//基础教材学科类别
hashTable.Add("themetype8","519");//教辅性质
//基础教材版别
hashTable.Add("usesegment","509");//基础教材使用学段
hashTable.Add("useterm","510");//基础教材使用学期
hashTable.Add("managemode","511");//编务管理类别
hashTable.Add("electype","608");//电子出版物类型 (dictid=608)
hashTable.Add("bindmode","516");//装帧形式
hashTable.Add("papersize","605");//纸张尺寸
hashTable.Add("isfund","517");//出版基金类别
*/
if(sql.Trim().Equals(""))
return;
if(DataFileds==null)
return;
if(filename.Equals(""))
filename="default";
int len;
string strInput;
StringWriter sw=new StringWriter();
//输出表头
if(Header!=null)
{
strInput="";
;len<Header.Length;len++)
{
if(Header[len]!=null)
{
if(strInput.Equals(""))
strInput=Header[len].ToString();
else
strInput+=filterStr+Header[len].ToString();
}
}//for(len=0;len<Header.Length;len++)
strInput="序号"+filterStr+strInput;
sw.WriteLine(strInput);
}//if(Header!=null)
DataTable dt=dbHandler.ExecuteDataTable(sql);
dt=CncBw.Db.ThemeInfoSet.ThemeInfoDictTransfer(dt);
;
foreach(DataRow dr in dt.Rows)
{
strInput="";
row+=;
;len<DataFileds.Length;len++)
{
)
{
//输入字段,输出数据
if(dr[DataFileds[len].ToString()]!=null)
{
strTemp=dr[DataFileds[len].ToString()].ToString().Trim();
strTemp=strTemp.Replace(",",",");
strInput=strTemp;
}
else
{
strInput="null";
}//if(dr[DataFileds[len]]!=null)
}
else
{
if(dr[DataFileds[len].ToString()]!=null)
{
strTemp=dr[DataFileds[len].ToString()].ToString().Trim();
strTemp=strTemp.Replace(",",",");
strTemp = strTemp.Replace("\r\n", " ");
strInput+=filterStr+strTemp;
}
else
strInput+=filterStr+"null";
}//if(len==0)
}//for(len=0;len<DataFileds.Length;len++)
strInput=row.ToString()+filterStr+strInput;
sw.WriteLine(strInput);
}//foreach(DataRow dr in dt.Rows)
sw.Close();
Response.AddHeader("Content-Disposition", "attachment;filename="+filename+".csv");
Response.ContentType = "application/ms-excel";
Response.ContentEncoding=System.Text.Encoding.GetEncoding("GB2312");
//Response.ContentEncoding=System.Text.Encoding.GetEncoding("unicode");
Response.Write(sw);
Response.End();
dbHandler.Close();
}
二、调用
this.InputFileTheme(header,dataFileds,strSql,"bookinfo");
bianwu 哈希表输出到 excel的更多相关文章
- arcgis api for javascript 学习(三) 调用发布地图信息,并将地图属性信息输出到Excel表中
吐血推荐:网上搜了很久关于webgis地图属性表输出到Excel表,并没能找到相关有价值的信息,在小白面前,这就是一脸懵x啊!网上要么是关于前端如何在页面上直接导出excel,和webgis半毛钱关系 ...
- 【哈希表】CodeVs1230元素查找
一.写在前面 哈希表(Hash Table),又称散列表,是一种可以快速处理插入和查询操作的数据结构.哈希表体现着函数映射的思想,它将数据与其存储位置通过某种函数联系起来,其在查询时的高效性也体现在这 ...
- openssl lhash 数据结构哈希表
哈希表是一种数据结构,通过在记录的存储位置和它的关键字之间建立确定的对应关系,来快速查询表中的数据: openssl lhash.h 为我们提供了哈希表OPENSSL_LHASH 的相关接口,我们可以 ...
- hdu acm 1425 sort(哈希表思想)
sort Time Limit: 6000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- noip模拟赛 好元素 哈希表的第一题
这是一道关于 题2好元素 2s [问题描述] 小A一直认为,如果在一个由N个整数组成的数列{An}中,存在以下情况: Am+An+Ap = Ai (1 <= m, n, p < i < ...
- [转]net中哈希表的使用 Hashtable
本文转自:http://www.cnblogs.com/gsk99/archive/2011/08/28/2155988.html 以下是PetShop中DBHelper中的使用过程: //创建哈希表 ...
- Snowflake Snow Snowflakes(哈希表的应用)
Snowflake Snow Snowflakes Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 27312 Accep ...
- 索引器、哈希表Hashtabl、字典Dictionary(转)
一.索引器 索引器类似于属性,不同之处在于它们的get访问器采用参数.要声明类或结构上的索引器,使用this关键字. 示例: 索引器示例代码 /// <summary> /// 存储星 ...
- c# 哈希表跟函数
一.哈希表集合 先进后出,一个一个赋值,但只能一起取值. 1.哈希表的建立.赋值以及读取. 2.利用枚举类型打印出集合中的Key值和Value值. 二.函数 函数:能够独立完成某项功能的模块. 函数四 ...
随机推荐
- CSS浮动与清浮动
浮动 ( float css属性) float : left right Elements are floated horizontally, this means that an element c ...
- set ver on/off
set verify(或ver) on/off可以设置是否显示替代变量被替代前后的语句 SQL> set verify on SQL> select &num from d ...
- MySQL复制-设置延迟复制
mysql> stop slave ; Query OK, 0 rows affected (0.00 sec) mysql> change master to master_delay= ...
- 【转】Java多线程编程中易混淆的3个关键字( volatile、ThreadLocal、synchronized)总结
概述 最近在看<ThinKing In Java>,看到多线程章节时觉得有一些概念比较容易混淆有必要总结一下,虽然都不是新的东西,不过还是蛮重要,很基本的,在开发或阅读源码中经常会遇到,在 ...
- linux:网络yum源和制作本地光盘yum源
linux:存放yum源的位置:/etc/yum.repos.d/,该目录下全是一些yum源 一.网络yum源: 如图:下面全部都是yum源,后缀是".repo"都是合法的yum源 ...
- HTML语言的一些元素(一)
1)标题的六个等级:<h1>,<h2>,<h3>,<h4>,<h5>,<h6>.如果写了诸如:<h7>等,则作为正文 ...
- 在xocde运行profile 遇到"Existing default base temp directory '/Library/Caches/com.apple.dt.instruments' has insufficient privileges for user id 505. Please have the owner delete this directory"
找到这篇文章 http://stackoverflow.com/questions/34153795/xcode-7-unable-to-open-instruments-from-developer ...
- Xcode 遇到 App Transport Security has blocked a cleartext HTTP 错误
今天用Xcode 创建新项目用到 URL 发送请求时,报下面的错: “App Transport Security has blocked a cleartext HTTP (http://) re ...
- Leetcode: Random Pick Index
Given an array of integers with possible duplicates, randomly output the index of a given target num ...
- 转:python webdriver API 之alert/confirm/prompt 处理
webdriver 中处理 JavaScript 所生成的 alert.confirm 以及 prompt 是很简单的.具体思路是使用switch_to.alert()方法定位到 alert/conf ...