zoukankan      html  css  js  c++  java
  • C# html的Table导出到Excel中

    C#中导出Excel分为两大类。一类是Winform的,一类是Web。今天说的这一种是Web中的一种,把页面上的Table部分导出到Excel中。

    Table导出Excel,简单点说,分为以下几步:

    1.根据table的id,获取到Table的html,如用jquery获取table的代码:$("#table").html().但这只是获取到<table></table>之间的内容,还需要拼接上。

    2.把页面获取到的table的html代码提交到后台。

    3.后台的Response设置了一下要导出的格式,导出的编码,和导出的文件名。

    具体详细,看一下下面的代码。

    (1)获取table

    var tableHead = "<html><meta http-equiv="content-type" content="text/html; charset=UTF-8" /><body><table><tr><td style="background-color: #84aced;">社員番号</td><td style="background-color: #84aced;">社員名前</td><td style="background-color: #84aced;">拠点</td>"
                                + "<td style="background-color: #84aced;">分野</td><td style="background-color: #84aced;">課</td><td style="background-color: #84aced;">職位</td><td style="background-color: #84aced;">"
                                + "対象</td><td style="background-color: #84aced;">一次評価者</td><td style="background-color: #84aced;">二次評価者</td><td style="background-color: #84aced;">操作</td></tr>";
    $("#html").val(tableHead + $("#datalist").html() + "</table></body></html>"); //获取并拼接代码

    (2)因为获取表格的html代码比较长,通过Form表单的形式提交个后台

     document.getElementById("ExcelForm").submit();

    (3)后台将获取到的table代码导出到Excel中

      string excelHtml = context.Request["excelHtml"];
                string name = DateTime.Now.ToString();
                context.Response.Buffer = true;
                //输出的应用类型 
                context.Response.ContentType = "application/vnd.ms-excel";
                //设定编码方式,若输出的excel有乱码,可优先从编码方面解决
                context.Response.Charset = "utf-8";
                context.Response.ContentEncoding = System.Text.Encoding.UTF8;
                //filenames是自定义的文件名
                context.Response.AppendHeader("Content-Disposition", "attachment;filename=" + name + ".xls");
                //content是步骤1的html,注意是string类型
                context.Response.Write(excelHtml);
                context.Response.End();
  • 相关阅读:
    Oracle 的日期类型
    简单的同步Socket程序服务端
    MMORPG中的相机跟随算法
    使用了UnityEditor中的API,打包时却不能打包UnityEditor的问题
    C# 中的关键字整理
    Unity3D C#中使用LINQ查询(与 SQL的区别)
    C# 值类型与引用类型的异同
    Unity3D NGUI事件监听的综合管理
    Unity3D 动画状态机简单控制核心代码
    Unity3D判断触摸方向
  • 原文地址:https://www.cnblogs.com/shunxiyuan/p/3238461.html
Copyright © 2011-2022 走看看