//调用
 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. 互斥锁Demo

    #include <stdio.h> #include <pthread.h> pthread_t work1Id; pthread_t work2Id; ; ; pthrea ...

  2. tomcat 相关异常

    端口没有被占用却提示Several ports (8005, 8080, 8009) required by Tomcat??? 解决办法:1.运行cmd进入命令行界面:2.运行命令: netsh w ...

  3. python re.findall 使用

    python re.findall 使用 import re #\w 匹配字母数字及下划线 print(re.findall('\w','hello alan _god !@^&#^$^!*& ...

  4. 【开发者笔记】Linq 多表关联排序操作

    c# 一直是一门好用的语言,但是像linq这种骚操作实在是记不住.特此记下以备后用. var ls = from c in db.T_ProductReturnEntity join s in db. ...

  5. kuangbin专题十三-基础计算几何

    链接:https://cn.vjudge.net/contest/68968 POJ 2318 TOYS 题意:m个玩具落在n+1个区间,给你玩具的坐标,问每个区间有多少玩具. 思路:叉积的简单应用, ...

  6. 前端(二十)—— vue介绍:引用vue、vue实例、实例生命周期钩子

    vue 一.认识Vue 定义:一个构建数据驱动的 web 界面的渐进式框架 优点: 1.可以完全通过客户端浏览器渲染页面,服务器端只提供数据 2.方便构建单页面应用程序(SPA) 3.数据驱动 =&g ...

  7. MySql 主从复制及深入了解

    分享一个不错的mysql文章 https://segmentfault.com/a/1190000008942618

  8. 访问nginx时验证密码

    只允许1.2.3.4这个IP访问我们的站点,拒绝所有其他IP的访问. server { listen 80; server_name www.example.com; satisfy any; all ...

  9. react 父子组件传值

    父组件向子组件传递信息 父组件片段 constructor(props){ super(props) this.state={ message:"我是父组件传来的" } } ren ...

  10. 安装Hama的基本过程