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的更多相关文章

  1. C# DataSet导出Excel

    //多个DataSet导出Excel文件 public static void DataSetToExcel(DataSet p_ds,string strSavePath) { ;//多个DataS ...

  2. 支持IE,FireFox,Chrome三大主流浏览器,通过js+Flash方式将table导出Excel文件

    今天在做项目的时候,遇到了前端下载Excel的功能,结果原先的代码,如下: function generate_excel(tableid) {        var table = document ...

  3. NPOI DataSet导出excel

    /// <summary> /// DataSet导出到Excel的MemoryStream /// </summary> /// <param name="d ...

  4. 170313、poi:采用自定义注解的方式导入、导出excel(这种方式比较好扩展)

    步骤一.自定义注解 步骤二.写Excel泛型工具类 步骤三.在需要导出excel的类属相上加上自定义注解,并设置 步骤四.写service,controller 步骤一:自定义注解 import ja ...

  5. DataSet导出Excel,比以往的方法导出的Excel外观更加好看

    原文发布时间为:2010-06-21 -- 来源于本人的百度文章 [由搬家工具导入] ======目前方法=========== #region 生成Excel/// <summary>/ ...

  6. form表单提交方式实现浏览器导出Excel

    刚开始使用ajax做Excel导出,发现ajax做不了浏览器导出只能下载到本地,于是用form提交可以提供浏览器下载Excel. 1>用ajax做本地下载: FileOutputStream f ...

  7. 【C#-导出Excel】DataSet导出Excel

    1.添加引用 2.封装方法 using System; using System.Data; using System.IO; using NPOI.HSSF.UserModel; using NPO ...

  8. 分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility (续篇)

    上周六我发表的文章<分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility>受到了大家的热烈支持与推荐,再此表示感谢,该ExcelUtility ...

  9. [转] Asp.Net 导出 Excel 数据的9种方案

    湛刚 de BLOG 原文地址 Asp.Net 导出 Excel 数据的9种方案 简介 Excel 的强大之处在于它不仅仅只能打开Excel格式的文档,它还能打开CSV格式.Tab格式.website ...

随机推荐

  1. 相关子查询和嵌套子查询 [SQL Server]

    SQLServer子查询可以分为 相关子查询 和 嵌套子查询 两类.前提,假设Books表如下: 类编号  图书名         出版社               价格-------------- ...

  2. 谷歌被爆秘密研发新系统 欲5年内取代Android

    谷歌2年多来有一群工程师秘密研发新系统,希望最终能取代手机操作系统安卓.安卓日前遭欧盟以反垄断为由重罚. 谷歌的新研发计划Fuchsia是从零开始,希望在更多个人装置和各式小巧装置联机上网的情况下,能 ...

  3. Centos 7.3下 Linux For SQL Server安装及配置介绍

    Centos 7.3下 Linux For SQL Server安装及配置介绍 高文龙关注13人评论2828人阅读2017-03-05 21:46:21 Centos 7.3下Linux For SQ ...

  4. SQL Server 2012-2016-2017 简体中文版下载和序列号

    注:本文来源于<SQL Server 2012-2016-2017 简体中文版下载和序列号> SqlServer 2017 下载地址及密钥 下载地址:ed2k://|file|cn_sql ...

  5. Confluence 6 配置草稿保存的时间

    这个设置仅仅应用到 Confluence 6.0 及后续版本中,如果你选择 禁用(disable )collaborative editing. 当协同编辑被启用后,我们将会保存所有的修改. 当协同编 ...

  6. Confluence 6 用户目录图例 - 使用 LDAP 授权,在用户第一次登陆时拷贝用户

    上面的图:Confluence 连接到一个 LDAP 目录只用作授权,当用户登录 Confluence 的时候,使用 LDAP 授权并且将用户信息同步到本地路服务器上. https://www.cwi ...

  7. 2017-2018-2 20165314 实验三《 敏捷开发与XP实践》实验报告

    知识点: 1.XP团队使用现场客户.特殊计划方法和持续测试来提供快速的反馈和全面的交流: -XP是以开发符合客户需要的软件为目标而产生的一种方法论 -XP是一种以实践为基础的软件工程过程和思想 -XP ...

  8. Tmk吃汤饭

    问题 : Tmk吃汤饭 时间限制: 1 Sec  内存限制: 128 MB 题目描述 Tmk喜欢吃汤饭! Tmk喜欢吃汤饭!! Tmk喜欢吃汤饭!!! 汤饭窗口分点餐和取餐两个窗口,一位蜀黍负责点餐窗 ...

  9. shell之ulimit应该注意的事项

    详细介绍:http://www.cnblogs.com/xiaOt119/archive/2012/06/13/2547930.html ulimit -n 2048 1.这个限制是针对单个程序的限制 ...

  10. Loadrunner Web (HTTP/HTML) 接口测试

    Action() { int nHttpRetCode;   lr_rendezvous("read"); lr_start_transaction("go    /*w ...