• WEB版利用NPOI导出数据库数据为Excel文件


    上一篇中,我已经提供了NPOI的dll文件下载

    没有下载的同学可以通过上一篇进行下载

    注意:html页面一定不能是用ajax去请求一般处理程序,Jquery的ajax函数的返回类型只有xml、text、json、html等类型,没有流类型,

    所以不能通过ajax实现文件的下载,即不能使用ajax函数。正确的文件下载方式是使用a标签。

    一定要同<a href="....../a.ashx">下载</a>这样的请求方式才可以,需要传参的话,直接在后面拼上就行

    我这里只是基本演示操作,用的是vs的控件。

    这里就直接上Demo代码

    前台代码

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="导出到Excel.aspx.cs" Inherits="导出到Excel" %>
    
    <!DOCTYPE html>
    
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
        <title></title>
    </head>
    <body>
        <form id="form1" runat="server">
        <div>
            <asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click" />
        </div>
        </form>
    </body>
    </html>

    后台代码

    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Linq;
    using System.Web;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using NPOI;
    using NPOI.SS.UserModel;
    using System.IO;
    public partial class 导出到Excel : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
    
        }
        protected void Button1_Click(object sender, EventArgs e)
        {
    
            DataTable dt =//利用你的orm框架得到数据源DataTable
            if (dt.Rows.Count > 0)
            {
                //创建工作簿
                NPOI.SS.UserModel.IWorkbook workbook = new NPOI.HSSF.UserModel.HSSFWorkbook();
                //创建表
                ISheet sheet = workbook.CreateSheet("vinkong");//表名
                IRow row0 = sheet.CreateRow(0);
                row0.CreateCell(0).SetCellValue("id信息");
                row0.CreateCell(1).SetCellValue("名称信息");
                row0.CreateCell(2).SetCellValue("备注信息");
                for (int r = 0; r < dt.Rows.Count; r++)
                {
                    //创建行接受DataTable的行数据
                    IRow row = sheet.CreateRow(r + 1);
                    row.CreateCell(0).SetCellValue(dt.Rows[r]["ID"].ToString());
                    row.CreateCell(1).SetCellValue(dt.Rows[r]["Code"].ToString());
                    row.CreateCell(2).SetCellValue(dt.Rows[r]["Name"].ToString());
    
                }
                string filePath = Server.MapPath(@"./Files/vinkong" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls");//存到项目Files文件夹下
    
                //写文件
                FileStream file = new FileStream(filePath, FileMode.Create);
                workbook.Write(file);
                file.Close();
    
    
                //下载
                FileInfo fileInfo = new FileInfo(filePath);
                Response.Clear();
                Response.ClearContent();
                Response.ClearHeaders();
                Response.AddHeader("Content-Disposition", "attachment;filename=" + fileInfo.Name);
                Response.AddHeader("Content-Length", fileInfo.Length.ToString());
                Response.AddHeader("Content-Transfer-Encoding", "binary");
                Response.ContentType = "application/octet-stream";
                Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312");
                Response.WriteFile(fileInfo.FullName);
                Response.Flush();
                //删除文件
                System.IO.File.Delete(filePath);
    
                Response.End();
            }
            else
            {
                Response.Write("<script>alert('导出失败!')</script>");
            }
        }
    }
  • 相关阅读:
    pat1111-1120
    pat1101-1110
    pat1091-1100
    pat1081-1090
    pat1071-1080
    pat1061-1070
    2017华为软件精英挑战赛总结
    pat1051-1060
    【转】WPF中PasswordBox控件的Password属性的数据绑定
    Python学习-41.Python中的断言
  • 原文地址:https://www.cnblogs.com/Vinkong/p/12618545.html
Copyright © 2020-2023  润新知