//调用
 public ActionResult GenerateExcel() {
            DataTable headerTable = new DataTable();
            headerTable.Columns.Add("Status_Id", Type.GetType("System.String"));
            headerTable.Columns.Add("Status_Name", Type.GetType("System.String"));
            headerTable.Columns.Add("Is_Now", Type.GetType("System.String"));
            headerTable.Columns.Add("Curr_User_Id", Type.GetType("System.String"));
            headerTable.Columns.Add("Flow_Id", Type.GetType("System.String"));
           
            DataRow headerRow = headerTable.NewRow();
            headerRow["Status_Id"] = "Status_Id";
            headerRow["Status_Name"] = "Status_Name";
            headerRow["Is_Now"] = "Is_Now";
            headerRow["Curr_User_Id"] = "Curr_User_Id";
            headerRow["Flow_Id"] = "Flow_Id";
            headerTable.Rows.Add(headerRow);

            DataTable contentTable = getDataByProc();

            generateExcelOP(headerTable, contentTable);
            ViewData["result"] = "Create successfully";
            return View("ExcelUpload");
        }

        //生成Excel

        public void generateExcelOP(DataTable headerTable,DataTable dt) {

            HSSFWorkbook workbook = new HSSFWorkbook();
            HSSFSheet sheet = workbook.CreateSheet() as HSSFSheet;

            //excel header info
            HSSFRow headerRow = sheet.CreateRow(0) as HSSFRow;
            for(int i = 0 ;i < headerTable.Columns.Count;i++){
                HSSFCell headerCell = headerRow.CreateCell(i) as HSSFCell;
                headerCell.SetCellValue(headerTable.Rows[0][i].ToString());
                headerRow.Cells.Add(headerCell);
            }

            //excel content info
            for(int m =0 ;m < dt.Rows.Count;m++){
                HSSFRow row = sheet.CreateRow((m+1)) as HSSFRow;
                for (int n = 0; n < dt.Columns.Count;n++ )
                {
                    HSSFCell cell = row.CreateCell(n) as HSSFCell;
                    cell.SetCellValue(dt.Rows[m][n].ToString());
                    row.Cells.Add(cell);
                }
            }

            FileStream fs = new FileStream(@"D:\data\output.xls", FileMode.Create);
            workbook.Write(fs);
            fs.Flush();
            fs.Close();
            workbook.Clear();
        }

 

       //获取数据

        public DataTable getDataByProc() {
            DataTable dt = new DataTable();
            string callName = "GetAuthHistory";
            string devConn = System.Configuration.ConfigurationManager.ConnectionStrings["devConn"].ToString();
            using(SqlConnection conn = new SqlConnection(devConn)){
                SqlCommand command = new SqlCommand(callName, conn);
                command.CommandType = CommandType.StoredProcedure;
                SqlParameter[] sps = {
                                     new SqlParameter("@currPage",SqlDbType.Int),
                                      new SqlParameter("@pageSize",SqlDbType.Int)
                                     };
                sps[0].Value = 1;
                sps[1].Value = 20;
               foreach(SqlParameter sp in sps){
                   command.Parameters.Add(sp);
               }
               SqlDataAdapter sda = new SqlDataAdapter();
               sda.SelectCommand = command;
               sda.Fill(dt);
            }

            return dt;
        }

调用存储过程取到数据通过NPOI存到Excel中的更多相关文章

  1. python 数据如何保存到excel中--xlwt

    第一步:下载xlwt 首先要下载xlwt,(前提是你已经安装好了Python) 下载地址:  https://pypi.python.org/pypi/xlwt/   下载第二个   第二步:安装xl ...

  2. ffmpeg从AVFrame取出yuv数据到保存到char*中

    ffmpeg从AVFrame取出yuv数据到保存到char*中   很多人一直不知道怎么利用ffmpeg从AVFrame取出yuv数据到保存到char*中,下面代码将yuv420p和yuv422p的数 ...

  3. 数据可视化之powerBI基础(十一)Power BI中的数据如何导出到Excel中?

    https://zhuanlan.zhihu.com/p/64415543 把Excel中数据加载到PowerBI中我们都已经熟悉了,但是怎么把在PowerBI中处理好的数据导出到Excel中呢?毕竟 ...

  4. 把数据库里面的stu表中的数据,导出到excel中

    # 2.写代码实现,把我的数据库里面的stu表中的数据,导出到excel中 #编号 名字 性别 # 需求分析:# 1.连接好数据库,写好SQL,查到数据 [[1,'name1','男'],[1,'na ...

  5. python爬取数据保存到Excel中

    # -*- conding:utf-8 -*- # 1.两页的内容 # 2.抓取每页title和URL # 3.根据title创建文件,发送URL请求,提取数据 import requests fro ...

  6. 「拉勾网」薪资调查的小爬虫,并将抓取结果保存到excel中

    学习Python也有一段时间了,各种理论知识大体上也算略知一二了,今天就进入实战演练:通过Python来编写一个拉勾网薪资调查的小爬虫. 第一步:分析网站的请求过程 我们在查看拉勾网上的招聘信息的时候 ...

  7. 使用Npoi向Excel中插入图片

    先把数据库中的数据都导入到Excel表格中,把图片地址的路径全部转成绝对路径. 使用Npoi读取刚导出的Excle表格,把图片那个单元格的图片路径读出来,然后用文件流读取图片,然后通过Npoi把图片放 ...

  8. 用Python提取XML里的内容,存到Excel中

    最近做一个项目是解析XML文件,提取其中的chatid和lt.timestamp等信息,存到excel里. 1.解析xml,提取数据 使用python自带的xml.dom中的minidom(也可以用l ...

  9. c# 应用NPOI 获取Excel中的图片,保存至本地的算法

    要求:读取excel中的图片,保存到指定路径 思路:  利用NPOI中 GetAllPictures()方法获取图片信息 步骤: 1.新建一个Windows窗体应用程序 2.桌面新建一个excel,贴 ...

随机推荐

  1. 关闭windows的DEP

    1.与开启dep时一样,按组合键win+r打开运行窗口,输入cmd并按回车,如图所示:    2.调出命令提示符窗口后,输入bcdedit.exe/set {current} nx AlwaysOff ...

  2. unzip失败,unzip:报错End-of-central-directory signature not found、scp:报错no space left on device

    文章目录 问题 解决 拓展 问题 通过rz命令传本地文件到本地服务器,失败. 通过scp命令尝试报错: no space left on device 意思是目的机器内存不够用了,但是传过去了,但是没 ...

  3. sublime 文件无法拖放

    sublime 文件无法拖放解决方法 https://github.com/emetio/pyv8-binaries 解决: 1. 去gihub下载 PyV8,连接地址:https://github. ...

  4. ASP.NET中ajax验证用户名和邮箱是否重复

    这个是前台显示的页面代码↓ <%@ Page Language="C#" AutoEventWireup="true" CodeFile="De ...

  5. 7年Java后端被淘汰,一路北漂辛酸史。。。

    作者:春天花会开foryou oschina.net/question/3465562_2281392 今天分享一位同行的经历: 本人Java开发6年半不到7年的样子. 英语专业,临毕业跟着隔壁专业去 ...

  6. LBP算子

    LBP算子特点 LBP(Local Binary Pattern),即局部二值模式,属于一种图像预处理算法,具有光照不变性和旋转不变性. 我目前做的项目是人脸表情识别,采用这种算法可以减少光照和人脸旋 ...

  7. uoj#244. 【UER #7】短路

    题目 orz myy 这个矩形对称的性质非常优美,所以我们只需要考虑一个\(\frac{1}{4}\)的矩阵,即一个倒三角形 现在我们要求的是从\((1,1)\)到三角形对边上每个点的最短路,不难发现 ...

  8. 矢量切片应用中geoserver与geowebcache分布式部署方案

    在进行GIS项目开发中,常使用Geoserver作为开源的地图服务器,Geoserver是一个JavaEE项目,常通过Tomcat进行部署.而GeoWebCache是一个采用Java实现用于缓存WMS ...

  9. 关于第一次将STM32与电脑连接情况

    安装了Keil(ARM)版本之后,不管是自己编程,还是配套的程序运行.我们都想把它下载到STM32芯片里面,在板子上运行.这里介绍几种方法. 1.用J-LINK下载调试. 这个工具,可以直接点击kei ...

  10. 笔记54 Mybatis快速入门(五)

    Mybatis中注解的使用 1.XML方式的CRUD 新增加接口CategoryMapper ,并在接口中声明的方法上,加上注解对比配置文件Category.xml,其实就是把SQL语句从XML挪到了 ...