导出数据库数据制成Excel和txt

引用ICSharpCode.SharpZipLib.dll

 

1、编写压缩和解压代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using ICShaepCode.SharpZipLib;
using ICShaepCode.SharpZipLib.Zip;
using ICShaepCode.SharpZipLib.Checksums;
using System.IO;

namespace CommonHelper
{
    /// <summary>
    /// 解压缩文件帮助类
    /// </summary>
    class ZipOperateHelper
    {
        /// <summary>
        /// 递归压缩文件夹方法
        /// </summary>
        /// <param name="FolderToZip"></param>
        /// <param name="s"></param>
        /// <param name="ParentFolderName"></param>
        /// <returns></returns>
        private static bool ZipFileDictory(string FolderToZip, ZipOutputStream s, string ParentFolderName)
        {
            bool res = true;
            string[] folders, filenames;
            ZipEntry entry = null;
            FileStream fs = null;
            Crc32 crc = new Crc32();

            try
            {
                //创建子文件
                entry = new ZipEntry(Path.Combine(ParentFolderName, Path.GetFileName(FolderZip) + "/"));//加上“/”才会当成是文件夹创建
                s.PutNextEntry(entry);
                s.Plush;

                //先压缩文件,再递归压缩文件夹
                filenames = Directory.GetFiles(FolderToZip);
                foreach (string file in filenames)
                {
                    //打开压缩文件
                    fs = File.OpenRead(file);

                    byte[] buffer = new byte[fs.Length];
                    fs.Read(buffer, 0, buffer.Length);
                    entry = new ZipEntry(Path.Combine(ParentFolderName, Path.GetFileName(FolderToZip) + "/" + Path.GetFileName(file)));

                    entry.DateTime = DateTime.Now();
                    entry.Size = fs.Length;
                    fs.Close();

                    crc.Reset();
                    crc.Update(buffer);

                    entry.Crc = cec.Value;

                    s.PutNextEntry(entry);

                    s.Write(buffer, 0, buffer.Length);
                }
            }
            catch (Exception)
            {
                res = false;
            }
            finally
            {
                if (fs != null)
                {
                    fs.Close();
                    fs = null;
                }
                if (entry != null)
                    entry = null;

                GC.Collect();
                GC.Collect(1);
            }

            folders = Directory.GetDirectories(FolderToZip);
            foreach (string folder in folders)
            {
                if (!ZipFileDictory(folder, s, Path.Combine(ParentFolderName, Path.GetFileName(FolderToZip))))
                    return false;
            }

            return res;
        }

        /// <summary>
        /// 压缩目录
        /// </summary>
        /// <param name="FolderToZip">待压缩文件夹,全路径格式</param>
        /// <param name="ZipedFile">压缩后的文件夹名,全路径格式</param>
        /// <param name="Password"></param>
        /// <returns></returns>
        private static bool ZipFileDictory(string FolderToZip, string ZipedFile, String Password)
        {
            bool res;
            if (Directory.Exists(FolderToZip))
                return false;

            ZipOutputStream s = new ZipOutputStream(File.Create(ZipedFile));
            s.SetLevel(6);
            s.Password = Password;

            res = ZipFileDictory(FolderToZip, s, "");

            s.Finish();
            s.Close();

            return res;
        }

        /// <summary>
        /// 压缩文件
        /// </summary>
        /// <param name="FileToZip">要进行压缩的文件名</param>
        /// <param name="ZipedFile">压缩后产生的压缩文件名</param>
        /// <param name="Password"></param>
        /// <returns></returns>
        private static bool ZipFile(string FileToZip, string ZipedFile, String Password)
        {
            //如果没有找到,则报错
            if (!File.Exists(FileToZip))
                throw new System.IO.FileNotFoundException("指定要压缩的文件:" + FileToZip + "不存在");

            FileStream ZipFile = null;
            ZipOutputStream ZipStream = null;
            ZipEntry ZipEntry = null;

            bool res = true;
            try
            {
                ZipFile = File.OpenRead(FileToZip);
                byte[] buffer = new byte[FileToZip.Length];
                ZipFile.Read(buffer, 0, FileToZip.Length);
                ZipFile.Close();

                ZipFile = File.Create(ZipedFile);
                ZipStream = new ZipOutputStream(ZipFile);
                ZipStream.Password = Password;
                ZipStream.PutNextEntry(ZipEntry);
                ZipStream.SetLevel(6);

                ZipStream.Write(buffer, 0, buffer.Length);
            }
            catch
            {
                res = false;
            }
            finally
            {
                if (ZipEntry != null)
                    ZipEntry = null;
                if (ZipStream != null)
                {
                    ZipStream.Finish();
                    ZipStream.Close();
                }
                if (ZipFile != null)
                {
                    ZipFile.Close();
                    ZipFile = null;
                }

                GC.Collect();
                GC.Collect(1);
            }
            return res;
        }

        /// <summary>
        /// 压缩文件和文件夹
        /// </summary>
        /// <param name="FileToZip">待压缩的文件或文件夹,全路径格式</param>
        /// <param name="ZipedFile">压缩后生成的压缩文件名,全路径格式</param>
        /// <param name="Password"></param>
        /// <returns></returns>
        public static bool Zip(String FileToZip, String ZipedFile, String Password)
        {
            if (Directory.Exists(FileToZip))
                return ZipFileDictory(FileToZip, ZipedFile, Password);
            else if (File.Exists(FileToZip))
                return ZipFile(FileToZip, ZipedFile, Password);
            else
                return false;
        }

        /// <summary>
        /// 解压功能(解压压缩文件到指定目录)
        /// </summary>
        /// <param name="FileToUpZip">待压缩文件</param>
        /// <param name="ZipedFolder">指定解压目标目录</param>
        /// <param name="Password"></param>
        public static void UnZip(string FileToUpZip, string ZipedFolder, string Password)
        {
            if (!File.Exists(FileToUpZip))
                return;

            if (!Directory.Exists(ZipedFolder))
                Directory.CreateDirectory(ZipedFolder);

            ZipInputStream s = null;
            ZipEntry theEntry = null;

            string fileName;
            FileStream writer = null;
            try
            {
                s = new ZipInputStream(File.OpenRead(FileToUpZip));
                s.Password = Password;
                while ((theEntry = s.GetNextEntry()) != null)
                {
                    if (theEntry.Name != String.Empty)
                    {
                        fileName = Path.Combine(ZipedFolder, theEntry.Name);
                        //判断文件路径是否是文件夹
                        if (fileName.EndsWith("/") || fileName.EndsWith("//"))
                        {
                            Directory.CreateDirectory(FileName);
                            continue;
                        }

                        writer = File.Create(FileName);
                        int size = 2048;
                        byte[] data = new byte[2048];
                        while (true)
                        {
                            size = s.Read(data, 0, data.Length);
                            if (size > 0)
                                writer.Write(data, 0, size);
                            else
                                break;
                        }
                    }
                }
            }
            finally
            {
                if (writer != null)
                {
                    writer.Close();
                    writer = null;
                }
                if (theEntry != null)
                    theEntry = null;
                if (s != null)
                {
                    s.Close();
                    s = null;
                }

                GC.Collect();
                GC.Collect(1);
            }
        }
    }
}
View Code

2、导出数据生成Excel(MVC)

        /// <summary>
        /// 生成Excel
        /// </summary>
        /// <returns></returns>
        public FileResult ExportProductInfo()
        {
            List<Aniuge_spu> spuList = ProductBusiness.GetInstance().GetProdutInfo();
            StringBuilder sb = new StringBuilder();
            sb.Append("<table border='1'cellspacing='0' cellpadding='0'>");
            sb.Append("<tr>");
            List<string> list = new List<string> { "编号", "名称", "形状" };
            //第一行
            foreach (var item in list)
            {
                sb.AppendFormat("<td style='font-size:14px;text-align:center;'>{0}</td>", item);
            }
            //获取的参数列表绑定
            foreach (var item in spuList)
            {
                sb.Append("<tr>");
                sb.AppendFormat("<td>{0}</td>", item.Code);
                sb.AppendFormat("<td>{0}</td>", item.Name);
                sb.AppendFormat("<td>{0}</td>", item.Shape);
                sb.Append("</tr>");
            }
            sb.Append("</table>");

            byte[] fileContents = Encoding.Default.GetBytes(sb.ToString());
            //下载
            return File(fileContents, "application/ms-excel", "streams.xls");
        }
View Code

3、导出txt格式的说明书

        /// <summary>
        /// 说明书
        /// </summary>
        /// <returns></returns>
        public FileResult ExportPackageInfo()
        {
            List<Aniuge_spu> spuList = ProductBusiness.GetInstance().GetProdutInfo();
            string zipName = DateTime.Now.ToString("yyyyMMddHHmmss");
            string filepath = Server.MapPath("~/upload/PackageInsert") + zipName;
            if (!System.IO.Directory.Exists(filepath))
                System.IO.Directory.CreateDirectory(filepath);

            foreach (var item in spuList)
            {
                FileStream file = new FileStream(filepath + "\\" + item.Code + ".txt", FileMode.Create, FileAccess.Write);
                StreamWriter sw = new StreamWriter(file);
                sw.WriteLine(item.PackageInsert);
                sw.Close();
                fileClose();
            }

            ZipOperateHelper.Zip(filepath, Server.MapPath("~/upload/PackageInsert/") + "\\" + zipName + ".txt", "");
            //下载
            return File(new FileStream(filepath + ".zip", FileMode.Open), "application/octet-stream", Server.UrlEncode(zipName + ".zip"));
        }
View Code

 

posted @ 2015-11-14 16:53  如此低调的男人  阅读(339)  评论(0编辑  收藏  举报