【第二篇】.NET用NPOI读取Excel表格并在页面预览

博主用的是npoi2.0.1,支持.xls也支持.xlsx

直接上代码吧。

<table class="table table-bordered table-striped">
                        <thead>
                            <tr>
                                <th>Shape</th>
                                <th>Pcs</th>
                                <th>Sizw</th>
                                <th>Size Range</th>
                                <th>Color</th>
                                <th>Clarity</th>
                                <th>Rap-Price</th>
                                <th>Cut</th>
                                <th>POL</th>
                                <th>SYM</th>
                                <th>H&A</th>
                                <th>FL</th>
                                <th>Diam/LxW</th>
                                <th>Dep%</th>
                                <th>Tab%</th>
                                <th>Rap%</th>
                                <th>LAB1</th>
                                <th>CersNo</th>
                                <th>LAB2</th>
                                <th>CersNo</th>
                                <th>Price/ct¥</th>
                            </tr>
                        </thead>
                        <tbody id="td">
                        </tbody>
                    </table>

之后用了jquery.form.js

function uploadFile() {
        var options = {
            type: "post",
            enctype: "multipart/form-data",
            url: "UploadExcel",
            success: function (data) {
                if (data != null) {
                    $("#td").append(data);
                    $("#uploadData").css("display", "block");
                } else if (data == 0) {
                    layer.msg('文档加载失败!', { icon: 5 }, function () {
                        $("#uploadData").css("display", "none");
                    });
                } else if (data == -1) {
                    layer.msg('数据库连接失败!', { icon: 5 }, function () {
                        $("#uploadData").css("display", "none");
                    });
                }  else {
                    layer.msg('未知错误!', { icon: 5 }, function () {
                        $("#uploadData").css("display", "none");
                    });
                }
            },
            processData: true,
            global: true
        };
        $("#form").ajaxSubmit(options);
    }

跟着是动作方法

public ActionResult UploadExcel()
        {
            string rtn = "1";
            if (Request.Files.Count > 0)
            {
                HttpPostedFileBase file = Request.Files["File"];
                string newFile = Server.MapPath("~/Areas/Admin/UploadFile/StockImprot/") + DateTime.Now.ToString("yyyyMMddHHmmss") + file.FileName;
                while (System.IO.File.Exists(newFile))
                {
                    newFile = Server.MapPath("~/Areas/Admin/UploadFile/StockImprot/") + DateTime.Now.ToString("yyyyMMddHHmmss") + file.FileName;
                }
                file.SaveAs(newFile);
                DataTable ds = ExcelHelper.GetDataTable(newFile);
                if (ds != null)
                {
                    if (ds.Rows != null)
                    {
                        ViewData["datatable"] = ds;
                        return PartialView("_PartialDataTable");  //注意这里返回是的局部视图哦
                    }
                }
                else
                {
                    rtn = "0"; //文档加载失败
                }
            }
            else
            {
                rtn = "-1";
            }
            return Content(rtn);
        }

局部视图的代码

@if (ViewData["datatable"] != null)
{
    System.Data.DataTable dt = ViewData["datatable"] as System.Data.DataTable;
    foreach (System.Data.DataRow dr in dt.Rows)
    {
    <tr>
        <td>@dr[0].ToString()</td>
        <td>@dr[1].ToString()</td>
        <td>@dr[2].ToString()</td>
        <td>@dr[3].ToString()</td>
        <td>@dr[4].ToString()</td>
        <td>@dr[5].ToString()</td>
        <td>@dr[6].ToString()</td>
        <td>@dr[7].ToString()</td>
        <td>@dr[8].ToString()</td>
        <td>@dr[9].ToString()</td>
        <td>@dr[10].ToString()</td>
        <td>@dr[11].ToString()</td>
        <td>@dr[12].ToString()</td>
        <td>@dr[13].ToString()</td>
        <td>@dr[14].ToString()</td>
        <td>@dr[15].ToString()</td>
        <td>@dr[16].ToString()</td>
        <td>@dr[17].ToString()</td>
        <td>@dr[18].ToString()</td>
        <td>@dr[19].ToString()</td>
        <td>@dr[20].ToString()</td>
    </tr> 
    }
}

最后上一张效果图

QQ截图20150820144842

 

 

--------------------------------------------------------------------------------------------------------- 

转载请记得说明作者和出处哦-.-
作者:KingDuDu
原文出处:https://www.cnblogs.com/kingdudu/articles/4745151.html

---------------------------------------------------------------------------------------------------------

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值