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. ASP.NET Core之NLog使用

    1.新建ASP.NET Core项目 1.1选择项目 1.2选择.Net版本 2. 添加NLog插件 2.1 通过Nuget安装 2.2下载相关的插件 3.修改NLog配置文件 3.1添加NLog配置 ...

  2. Laravel 5.2--如何让表单提交错误,不清空?

    控制器 public function store(Request $request) { $validator = Validator::make($request->all(), [ 'Su ...

  3. appium+java(四)微信公众号自动化测试实践

    前言 随着手机阅读的普遍应用,微信公众号阅读,更为普遍,微信和qq一样,都是基于腾讯自研X5内核,不是google原生webview(其实就是进行了二次定制).实质上也是混合应用的一种,现在很多app ...

  4. [PHP]命名空间的一些要点

    1.命名空间前不能接"\": namespace MyProject\Sub\Level; // it's right; namespace \MyProject\Sub\Leve ...

  5. Python基础-入门之路PYTHON-包 相对导入&绝对导入

    什么是包 包也是一种模块,但本质上就是一个文件夹 对于使用者而言 使用方式和模块没有任何区别 本质上就是一个文件夹 不同之处在于 多了一个__init__.py 叫包的初始化文件 import导入模块 ...

  6. 通过printf从目标板到调试器的输出

    最近在SEGGER的博客上看到Johannes Lask写的一篇关于在调试时使用printf函数从目标MCU输出信息到调试器的文章,自我感觉很有启发,特此翻译此文并推荐给各位同仁.当然限于个人水平,有 ...

  7. checkstyle.xml Code Style for Eclipse

    1. Code Templates [下载 Code Templates] 打开 Eclipse -> Window -> Preferences -> Java -> Cod ...

  8. 在 Confluence 中启用 HTTP 响应压缩

    Confluence 能够支持 HTTP 的 GZip 传输编码.这个意味着 Confluence 将可以把数据压缩后传输给用户,这种配置能够针对不稳定的互联网状态下的传输速度缓慢和不稳定并且能够降低 ...

  9. Confluence 6 匿名访问远程 API

    Confluence 管理员可能希望为匿名用户禁用远程访问 API.这样能够避免恶意软件随意在网站进行批量修改. 希望禁用远程访问 API: 在屏幕的右上角单击 控制台按钮 ,然后选择 General ...

  10. Confluence 6 配置 Web 代理支持

    这个页面中的相关平台中的内容是不被支持的.因此,Atlassian 支持不能保证能够为你提供任何支持.请注意,这个页面下面提供的信息仅为你提供参考同时也不能保证所有的的配置能正常工作.如果你按照本页面 ...