zoukankan      html  css  js  c++  java
  • 利用MyXls导出Excel并下载

    导出Excel并且下载

    代码
    protected void butExport_Click(object sender, EventArgs e)
    {
    try
    {
    DataTable dt
    = GetList(StrSql).Tables[0];
    ExportExcel excel
    = new ExportExcel();
    string fileName = excel.Export(dt, DropDownList1.SelectedItem.Text, DataName);
    string path = Request.PhysicalApplicationPath + "Excel\\" + fileName + ".xls";
    DownFile.ResponseFile(Page.Request, Page.Response, fileName
    + ".xls", path, 1024000);



    FileInfo file
    = new FileInfo(path);
    file.Delete();
    }
    catch (Exception ex)
    {
    throw new AppException(ex);
    }

    }

    利用MyXls导出Excel

      

    代码
    /// <summary>
    /// 导出Excel
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    public string Export(DataTable dt, string xlsName, List<string> dataName)
    {
    XlsDocument xls
    = new XlsDocument();
    string fileName = DateTime.Now.ToString("yyyyMMddhhmmss");
    xls.FileName
    = fileName;



    Worksheet sheet
    = xls.Workbook.Worksheets.Add(xlsName);//Sheet名称

    Cells cells
    = sheet.Cells;

    Cell cell
    = cells.Add(1, 1, dataName[0].ToString());
    cell.Font.Bold
    = true;

    for (int i = 1; i < dataName.Count; i++)
    {
    cell
    = cells.Add(1, i + 1, dataName[i].ToString());
    cell.Font.Bold
    = true;

    }

    for (int i = 0; i < dt.Rows.Count; i++)
    {
    for (int j = 0; j < dt.Columns.Count; j++)
    {
    cells.Add(i
    + 2, j + 1, dt.Rows[i][j].ToString());
    }
    }

    string file = System.Web.HttpContext.Current.Server.MapPath("/Excel/");
    xls.Save(file);
    return fileName;
    }


    文件下载,目前用着还不错

      

    代码
    public static bool ResponseFile(HttpRequest _Request, HttpResponse _Response, string _fileName, string _fullPath, long _speed)
    {
    try
    {
    FileStream myFile
    = new FileStream(_fullPath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
    BinaryReader br
    = new BinaryReader(myFile);
    try
    {
    _Response.AddHeader(
    "Accept-Ranges", "bytes");
    _Response.Buffer
    = false;
    long fileLength = myFile.Length;
    long startBytes = 0;



    double pack = 10240; //10K bytes
    //int sleep = 200; //每秒5次 即5*10K bytes每秒
    int sleep = (int)Math.Floor(1000 * pack / _speed) + 1;
    if (_Request.Headers["Range"] != null)
    {
    _Response.StatusCode
    = 206;
    string[] range = _Request.Headers["Range"].Split(new char[] { '=', '-' });
    startBytes
    = Convert.ToInt64(range[1]);
    }
    _Response.AddHeader(
    "Content-Length", (fileLength - startBytes).ToString());
    if (startBytes != 0)
    {
    //Response.AddHeader("Content-Range", string.Format(" bytes {0}-{1}/{2}", startBytes, fileLength-1, fileLength));
    }
    _Response.AddHeader(
    "Connection", "Keep-Alive");
    _Response.ContentType
    = "application/octet-stream";
    _Response.AddHeader(
    "Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(_fileName, System.Text.Encoding.UTF8));

    br.BaseStream.Seek(startBytes, SeekOrigin.Begin);
    int maxCount = (int)Math.Floor((fileLength - startBytes) / pack) + 1;

    for (int i = 0; i < maxCount; i++)
    {
    if (_Response.IsClientConnected)
    {
    _Response.BinaryWrite(br.ReadBytes(
    int.Parse(pack.ToString())));
    Thread.Sleep(sleep);
    }
    else
    {
    i
    = maxCount;
    }
    }
    }
    catch
    {
    return false;
    }
    finally
    {
    br.Close();

    myFile.Close();
    }
    }
    catch
    {
    return false;
    }
    return true;
    }
  • 相关阅读:
    Flask-SQLAlchemy
    with 与 上下文管理器
    使用@property
    C++:如何把一个int转成4个字节?
    尝试理解Flask源码 之 搞懂WSGI协议
    qt setData()和data()
    我使用过的Linux命令之sftp
    linux下如何使用sftp命令
    Linux环境下安装JDK
    CentOS 6.5 配置IP地址的三种方法
  • 原文地址:https://www.cnblogs.com/smartsky/p/1839560.html
Copyright © 2011-2022 走看看