xml方式将dataset导出excel
using System;
using System.Collections;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading;
namespace Cinway.Common
{
public class xmlParam {
public string totalcount { get; set; }
public string startdt { get; set; }
public string enddt { get; set; }
public string xmlNum { get; set; }
public string deptcode { get; set; }
public string deptname { get; set; }
public string strstart { get; set; }
public string jszhu { get; set; }
public string jszhang { get; set; }
public string commonstr { get; set; }
public string filename { get; set; }//新增zp
}
public class ExcelToolNew
{
public FileStream ToExcel(DataSet ds,string headstr,string footstr,xmlParam pa) {
DataTable dt = ds.Tables[0];
int rowcount = dt.Rows.Count;
int rcount = dt.Rows.Count / 60;
DataSet dataset = SplitDataTable(dt, rcount);
dt.Clear();
string[] strfilename = new string[dataset.Tables.Count];
ManualResetEvent[] doneEvents = new ManualResetEvent[dataset.Tables.Count];
Fibonacci[] fibArray = new Fibonacci[dataset.Tables.Count];
int i = 0;
foreach (DataTable datatable in dataset.Tables)
{
string sfilename = "D:\\xmlfile\\" + Guid.NewGuid() + ".XML";
strfilename[i] = sfilename;
Fibonacci fi = new Fibonacci();
fi.WriteXML(datatable, sfilename, pa.xmlNum,pa.strstart);
i++;
}
string filename = "D:\\xmlfile\\" + Guid.NewGuid() + ".xml";
StreamReader srh = new StreamReader(System.Web.HttpContext.Current.Server.MapPath(headstr), Encoding.Default);//读出表头部内容
FileStream fs1 = new FileStream(filename, FileMode.OpenOrCreate);
StreamWriter sw1 = new StreamWriter(fs1, Encoding.UTF8);
sw1.WriteLine(srh.ReadToEnd().Replace("totalcount", pa.totalcount).Replace("StartDT", pa.startdt).Replace("EndDT",pa.enddt).Replace("deptcode", pa.deptcode).Replace("deptname", pa.deptname).Replace("jszhang", pa.jszhang).Replace("jszhu", pa.jszhu).Replace("commonstr", pa.commonstr));//把头部内容写到新文件中
for (int k = 0; k < strfilename.Length; k++)
{
StreamReader sr1 = new StreamReader(strfilename[k], Encoding.Default);
sw1.Write(sr1.ReadToEnd());//插入数据
}
StreamReader srf = new StreamReader(System.Web.HttpContext.Current.Server.MapPath(footstr), Encoding.Default);//读出表尾部内容
sw1.WriteLine(srf.ReadToEnd());
sw1.Close();
fs1.Close();
FileStream fsm = new FileStream(filename, FileMode.Open);
return fsm;
}
public string ToExcelnew(DataSet ds, string headstr, string footstr, xmlParam pa)
{
DataTable dt = ds.Tables[0];
int rowcount = dt.Rows.Count;
int rcount = dt.Rows.Count / 60;
DataSet dataset = SplitDataTable(dt, rcount);
dt.Clear();
string[] strfilename = new string[dataset.Tables.Count];
ManualResetEvent[] doneEvents = new ManualResetEvent[dataset.Tables.Count];
Fibonacci[] fibArray = new Fibonacci[dataset.Tables.Count];
int i = 0;
foreach (DataTable datatable in dataset.Tables)
{
string sfilename = "D:\\xmlfile\\" + Guid.NewGuid() + ".XML";
strfilename[i] = sfilename;
Fibonacci fi = new Fibonacci();
fi.WriteXML(datatable, sfilename, pa.xmlNum, pa.strstart);
i++;
}
string filename = "D:\\xmlfile\\" + Guid.NewGuid() + ".xml";
StreamReader srh = new StreamReader(System.Web.HttpContext.Current.Server.MapPath(headstr), Encoding.Default);//读出表头部内容
FileStream fs1 = new FileStream(filename, FileMode.OpenOrCreate);
StreamWriter sw1 = new StreamWriter(fs1, Encoding.UTF8);
sw1.WriteLine(srh.ReadToEnd().Replace("totalcount", pa.totalcount).Replace("StartDT", pa.startdt).Replace("EndDT", pa.enddt).Replace("deptcode", pa.deptcode).Replace("deptname", pa.deptname).Replace("jszhang", pa.jszhang).Replace("jszhu", pa.jszhu).Replace("commonstr", pa.commonstr));//把头部内容写到新文件中
for (int k = 0; k < strfilename.Length; k++)
{
StreamReader sr1 = new StreamReader(strfilename[k], Encoding.Default);
sw1.Write(sr1.ReadToEnd());//插入数据
}
StreamReader srf = new StreamReader(System.Web.HttpContext.Current.Server.MapPath(footstr), Encoding.Default);//读出表尾部内容
sw1.WriteLine(srf.ReadToEnd());
sw1.Close();
fs1.Close();
string strfileName = Common.SecurityEncrypt.ESCEncrypt(pa.filename, "20170421");
string strfilePath = Common.SecurityEncrypt.ESCEncrypt(filename, "20170421");
//FileStream fsm = new FileStream(filename, FileMode.Open);
return "filename=" + strfileName + "&filepath=" + strfilePath;
}
// DateTime enddt = DateTime.Now;
// FileStream fss = new FileStream("C:\\JISHI.TXT", FileMode.OpenOrCreate);
// StreamWriter sws = new StreamWriter(fss, Encoding.UTF8);
//sws.WriteLine(startdt.ToString() + "******" + enddt.ToString());
// sws.Close();
// fss.Close();
/// <summary>
/// 分解数据表
/// </summary>
/// <param name="originalTab">需要分解的表</param>
/// <param name="rowsNum">每个表包含的数据量</param>
/// <returns></returns>
public DataSet SplitDataTable(DataTable originalTab, int rowsNum)
{
//获取所需创建的表数量
if (rowsNum==0) {
rowsNum = 1;
}
int tableNum = originalTab.Rows.Count / rowsNum;
//获取数据余数
int remainder = originalTab.Rows.Count % rowsNum;
DataSet ds = new DataSet();
//如果只需要创建1个表,直接将原始表存入DataSet
if (tableNum == 0)
{
if (originalTab.Rows.Count==0) {
ds.Tables.Add(new DataTable());
}
else
{
ds.Tables.Add(originalTab);
}
}
else
{
DataTable[] tableSlice = new DataTable[tableNum];
//Save orginal columns into new table.
for (int c = 0; c < tableNum; c++)
{
tableSlice[c] = new DataTable();
foreach (DataColumn dc in originalTab.Columns)
{
tableSlice[c].Columns.Add(dc.ColumnName, dc.DataType);
}
}
//Import Rows
for (int i = 0; i < tableNum; i++)
{
// if the current table is not the last one
if (i != tableNum - 1)
{
for (int j = i * rowsNum; j < ((i + 1) * rowsNum); j++)
{
tableSlice[i].ImportRow(originalTab.Rows[j]);
}
}
else
{
for (int k = i * rowsNum; k < ((i + 1) * rowsNum + remainder); k++)
{
tableSlice[i].ImportRow(originalTab.Rows[k]);
}
}
}
//add all tables into a dataset
foreach (DataTable dt in tableSlice)
{
ds.Tables.Add(dt);
}
}
return ds;
}
public class Fibonacci
{
// ManualResetEvent _doneEvent;
public void WriteXML(DataTable dt, string filename,string xmlNum,string strstart)
{
FileStream fs1 = new FileStream(filename, FileMode.OpenOrCreate);
StreamWriter sw1 = new StreamWriter(fs1, Encoding.UTF8);
sw1.WriteLine("");
sw1.Close();
fs1.Close();
if (string.IsNullOrEmpty(strstart)) {
strstart = "<Cell ss:StyleID=\"" + xmlNum + "\"><Data ss:Type=\"String\">";
}
string strend = "</Data></Cell>";
int jishu = 0;
string xmlstr2 = "";
foreach (DataRow row in dt.Rows)
{
if (jishu == 10)
{
FileStream fs3 = new FileStream(filename, FileMode.Append);
StreamWriter sw3 = new StreamWriter(fs3, Encoding.UTF8);
sw3.WriteLine(xmlstr2);
sw3.Close();
fs3.Close();
xmlstr2 = "";
jishu = 0;
}
xmlstr2 += "<Row ss:AutoFitHeight=\"0\" ss:Height=\"18.9375\">";
for (int i = 0; i < row.ItemArray.Length; i++)
{
string str = row[i] == null ? "" : row[i].ToString();
if (str.Contains("<") || str.Contains(">"))
{
str = str.Replace('<', '<');
str = str.Replace('>', '>');
}
xmlstr2 += (strstart + str + strend);
}
xmlstr2 += "</Row>";
jishu++;
}
dt.Clear();
FileStream fs2 = new FileStream(filename, FileMode.Append);
StreamWriter sw2 = new StreamWriter(fs2, Encoding.UTF8);
sw2.WriteLine(xmlstr2);
sw2.Close();
fs2.Close();
}
}
}
}
xml方式将dataset导出excel的更多相关文章
- C# DataSet导出Excel
//多个DataSet导出Excel文件 public static void DataSetToExcel(DataSet p_ds,string strSavePath) { ;//多个DataS ...
- 支持IE,FireFox,Chrome三大主流浏览器,通过js+Flash方式将table导出Excel文件
今天在做项目的时候,遇到了前端下载Excel的功能,结果原先的代码,如下: function generate_excel(tableid) { var table = document ...
- NPOI DataSet导出excel
/// <summary> /// DataSet导出到Excel的MemoryStream /// </summary> /// <param name="d ...
- 170313、poi:采用自定义注解的方式导入、导出excel(这种方式比较好扩展)
步骤一.自定义注解 步骤二.写Excel泛型工具类 步骤三.在需要导出excel的类属相上加上自定义注解,并设置 步骤四.写service,controller 步骤一:自定义注解 import ja ...
- DataSet导出Excel,比以往的方法导出的Excel外观更加好看
原文发布时间为:2010-06-21 -- 来源于本人的百度文章 [由搬家工具导入] ======目前方法=========== #region 生成Excel/// <summary>/ ...
- form表单提交方式实现浏览器导出Excel
刚开始使用ajax做Excel导出,发现ajax做不了浏览器导出只能下载到本地,于是用form提交可以提供浏览器下载Excel. 1>用ajax做本地下载: FileOutputStream f ...
- 【C#-导出Excel】DataSet导出Excel
1.添加引用 2.封装方法 using System; using System.Data; using System.IO; using NPOI.HSSF.UserModel; using NPO ...
- 分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility (续篇)
上周六我发表的文章<分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility>受到了大家的热烈支持与推荐,再此表示感谢,该ExcelUtility ...
- [转] Asp.Net 导出 Excel 数据的9种方案
湛刚 de BLOG 原文地址 Asp.Net 导出 Excel 数据的9种方案 简介 Excel 的强大之处在于它不仅仅只能打开Excel格式的文档,它还能打开CSV格式.Tab格式.website ...
随机推荐
- 模块 -- 序列化 hashlib sha logging (加密 加盐 )
模块: 一个py文件就是一个模块 模块分类: 1:内置模块,登录模块,时间模块,sys模块,os模块等等 2: 扩展模块, 3:自定义模块,自己写的py文件 python 开发效率之高:python ...
- java8 lambda方法引用
注意引用方法的参数列表与返回值类型要与函数式接口中的抽象方法的参数列表与返回值类型保持一致 主要有三种语法格式: * * 对象::实例方法名 * * 类::静态方法名 * * 类::实例方法名 pub ...
- reportNG定制化之失败截图及日志
先从github上拉下 reportNg的源代码 reportng 拉下源码后我们使用IDEA进行导入 1.reportng.properties 增加部分类表项 这里我们直接在末尾添加 log=L ...
- [C]gcc编译器的一些常用语法
简单的GCC语法: 如果你只有一个文件(或者只有几个文件),那么就可以不写Makefile文件(当然有Makefile更加方便),用gcc直接编译就行了.在这里我们只介绍几个我经常用的几个参数,第一是 ...
- JavaScript自定义对象
一,概述 在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类.Hashtable类等等. 目前在Javascrip ...
- python-函数入门(二)
一.函数对象 什么是函数? 函数是第一类对象,指的是函数名指向的值(函数)可以被当做数据去使用 1.函数的特性 1.函数可以被引用,即函数可以把值赋值给一个变量 def foo(): print('f ...
- js之雪花飘落
有很多网站都有雪花或花瓣飘落的特效,看上去很好看.我来用js实现这个效果. 在写代码之前可以先引入bass.css对样式做下处理: 1.html部分 先建一个文件夹,在body中插入如下代码 < ...
- C语言学习及应用笔记之一:C运算符优先级及使用问题
C语言中的运算符绝对是C语言学习和使用的一个难点,因为在2011版的标准中,C语言的运算符的数量超过40个,甚至比关键字的数量还要多.这些运算符有单目运算符.双目运算符以及三目运算符,又涉及到左结合和 ...
- SQL*Plus工具
或者
- Confluence 6 从其他备份中恢复数据
一般来说,Confluence 数据库可以从 Administration Console 或者 Confluence Setup Wizard 中进行恢复. 如果你在恢复压缩的 XML 备份的时候遇 ...