使用NPOI库导入导出EXCEL

一、EXCEL  导入(Excel 导入导出实际项目中会被封装成**Helper 本示例只对简单功能做演示)

NPOI 包引用

视图view

@{ViewBag.Title = "NPOIExcel";
}<h2>NPOIExcel</h2>
<form action="@Url.Action("NPOIInport", "Home")" method="post" enctype="multipart/form-data"><input type="file" name="Importexcelfile" /><button type="submit">提交</button>
</form>//enctype="multipart/form-data"  上传文件时form 表单必加

Action

命名空间引用

using NPOI.SS.UserModel;
using NPOI.HSSF.UserModel;
using NPOI.XSSF.UserModel;
using System.Data;

 /// <summary>/// NPOI 导入excel/// </summary>/// <returns></returns>
        [HttpPost]public ActionResult NPOIInport(){bool isok = false;string msg = string.Empty;var file = Request.Files["Importexcelfile"];//接收的文件对象var filename = SaveUploadExcel(file);//将文件保存至某一路径下 并形成新的文件名称var filePath=System.Configuration.ConfigurationManager.AppSettings["Upload"] + @"\excel\" + filename;//新路径IWorkbook workbook = null; //定义工作簿接口ISheet sheet=null;//定义sheet表DataTable data = new DataTable();FileStream filestream = new FileStream(filePath, FileMode.Open, FileAccess.Read);if (file.ContentLength>0){if (filePath.IndexOf(".xlsx") > 0){workbook = new XSSFWorkbook(filestream);//.xlsx 文件
                }else{workbook = new HSSFWorkbook(filestream);//.xls文件
                }sheet = workbook.GetSheetAt(0);//默认第一个sheet sheet 下标//sheet = workbook.GetSheet("sheet的名字");//获取想要查询sheet的名字if (sheet!=null){for (int i = 0; i < sheet.LastRowNum; i++){IRow row = sheet.GetRow(i);//获取第一行 一般都是表头var firstvalue = row.GetCell(0);//第一行的第一列var secondvalue = row.GetCell(1);}//常见读取excel 已经够用  实际项目中会遇到 再次封装数据形成table  一般这个帮助类会叫**HelperIRow firstrow = sheet.GetRow(0);int cellcount = firstrow.LastCellNum;//总列数for (int i = firstrow.FirstCellNum; i < cellcount; i++){ICell icell = firstrow.GetCell(i);if (icell!=null){string cellvalue = icell.StringCellValue;//获取当前单元格的valueDataColumn column = new DataColumn(cellvalue);data.Columns.Add(column);//添加表头
                        }}int startrow = sheet.FirstRowNum + 1;for (int i = startrow; i < sheet.LastRowNum; i++){IRow row = sheet.GetRow(i);if (row!=null){DataRow datarow = data.NewRow();for (int j = row.FirstCellNum; j < cellcount; j++){if (row.GetCell(j)!=null){datarow[j] = row.GetCell(j).ToString();}}data.Rows.Add(datarow);}}//return data;
                }}return Json(new { Isok = isok, Msg = msg });}public static string SaveUploadExcel(HttpPostedFileBase fileexcel){string filename = fileexcel.FileName;string extension = Path.GetExtension(filename);int filesize = fileexcel.ContentLength;if (filesize>int.Parse(System.Configuration.ConfigurationManager.AppSettings["UploadFileSize"])){return "文件超过上限";}string dirPath = System.Configuration.ConfigurationManager.AppSettings["Upload"] + @"\excel\";//生成新的文件名string newFileName = string.Format("{0}{1}", DateTime.Now.ToString("yyMMddHHmmssfffffff"), extension);if (!Directory.Exists(dirPath))Directory.CreateDirectory(dirPath);fileexcel.SaveAs(dirPath + newFileName);//返回新生成的文件名称return newFileName;}
View Code

 

二、EXCEL 导出

 

 

 

转载于:https://www.cnblogs.com/eric-gms/p/6907595.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/355507.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

oracle12c ora 12547,Oracle 12c DBCA出现PRCR-1079 ORA-12547 CRS-5017

Oracle 12c用dbca创建数据库时出现了PRCR-1079 ORA-12547 CRS-5017不能启动数据库。因为这里安装了Oracle Restart&#xff0c;所以尝试使用srvctl start database命令来手动启动数据库&#xff0c;但是结果还是一样不能启动。[gridoracle12c 12.1]$ srvctl start database -db…

kmeans鸢尾花分类python代码_python实现鸢尾花三种聚类算法(K-means,AGNES,DBScan)

一.分散性聚类(kmeans) 算法流程: 1.选择聚类的个数k. 2.任意产生k个聚类&#xff0c;然后确定聚类中心&#xff0c;或者直接生成k个中心。 3.对每个点确定其聚类中心点。 4.再计算其聚类新中心。 5.重复以上步骤直到满足收敛要求。&#xff08;通常就是确定的中心点不再改变。…

akka_Akka的字数统计MapReduce

akka在我与Akka的日常工作中&#xff0c;我最近写了一个字数映射减少示例。 本示例实现了Map Reduce模型&#xff0c;该模型非常适合横向扩展设计方法。 流 客户端系统&#xff08;FileReadActor&#xff09;读取文本文件&#xff0c;并将每一行文本作为消息发送给ClientActor…

Log4j 2配置与IntelliJ IDEA控制台颜色

Log4j是Java平台上最好的日志组件了&#xff0c;Log4j 2升级了不少API&#xff0c;拓展性更好。使用的话只需要直接引入就可以了. <dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version> &…

用c3p0连接oracle怎么分页,JSP分页(MySql+c3p0+dbutils)

JSP分页(MySqlc3p0dbutils)来源&#xff1a;互联网作者&#xff1a;佚名时间&#xff1a;2015-02-16 17:27为什么要对数据进行分页&#xff1f;当数据较多时&#xff0c;页面就会变的很庞大&#xff0c;不仅会影响到用户的使用&#xff0c;而且还有加重服务器的负担。下面简单的…

用python自动发邮件_Python实现向QQ群成员自动发邮件的方法

#coding:utf-8 import random import smtplib from email.mime.text import MIMEText import time def send_mail(mailto): print Setting MIMEText CTopen(content.txt,r) #读取发送邮件内容 contentCT.read().decode(utf-8) msgMIMEText(content.encode(utf8),_subtypehtml) …

Apache Storm的实时情绪分析示例

实时情感分析是指处理自然语言文本&#xff08;或语音&#xff09;流以提取主观信息。 琐碎的用例用于构建推荐引擎或查找社交媒体趋势。 我选择了Apache Storm作为实时处理引擎。 Storm非常强大&#xff08;我们正在生产中使用它&#xff09;&#xff0c;并且非常容易在其之上…

产品经理在早期如何快速学习?

产品经理在早期如何快速学习&#xff1f; 1、多阅读 &#xff08;1&#xff09;阅读专业书籍 比如说小米的黎万强写了一本《参与感》&#xff0c;讲述了小米成长过程中的一系列案例分析&#xff0c;概念总结。黎老师是小米创始元老&#xff0c;案例有小米的成功背书&#xff0c…

linux ftp解压命令 cannot fid or open,Linux环境搭建及常用shell命令集锦

22.crontab –l 查看crontab命令行 (13)23.重定向 (13)24.ps –eaf | grep httpd 查找httpd进程 (13)25.kill -9 PID 强制停止进程 (13)26.rpm –ivh a.rpm 安装rpm包 (13)27.chmod 111(可执行)/222(可读)/444(可写) file 权限 (13)28.修改linux颜色在vim .bash_profile里添加e…

flink sql设置并行度_《从0到1学习Flink》—— Flink parallelism 和 Slot 介绍

前言之所以写这个是因为前段时间自己的项目出现过这样的一个问题&#xff1a;Caused by: akka.pattern.AskTimeoutException: Ask timed out on [Actor[akka://flink/user/taskmanager_0#15608456]] after [10000 ms]. Sender[null] sent message of type "org.apache.f…

zabbix3.2监控

自动化运维框架 运维标准流程监控管理容量管理、关联关系、任务管理、自动部署、分布式集群、传统集群、机器管理安全控制灾难管理 自动化监控 监控评估数据采集主动式数据采集: client、公共插件、自定义脚本被动式服务状态: 服务状态、程序状态、用户访问质量第三方信息 公…

linux使用创建es用户,linux用户权限设置(安装elasticsearch7.x)

前言今天下载了elasticsearch的7.x版本&#xff0c;使用bin/elasticsearch -d 启动后&#xff0c;报出如下错误&#xff1a;java.lang.RuntimeException: can not run elasticsearch as rootat org.elasticsearch.bootstrap.Bootstrap.initializeNatives(Bootstrap.java:105)at…

fasttext 文本分类_一文综述经典的深度文本分类方法

作者 | 何从庆转载自AI算法之心(ID:AIHeartForYou)笔者整理最近几年比较经典的深度文本分类方法&#xff0c;希望帮助小伙伴们了解深度学习在文本分类中的应用。Convolutional Neural Networks for Sentence Classification (EMNLP 2014)Kim在EMNLP2014提出的TextCNN方法&…

Java 8 Streams API:对流进行分组和分区

这篇文章展示了如何使用Streams API中可用的Collectors将具有groupingBy的流元素和具有partitioningBy的流元素进行groupingBy 。 考虑一系列Employee对象&#xff0c;每个对象都有名称&#xff0c;城市和销售数量&#xff0c;如下表所示&#xff1a; ----------------------…

vi/vim 编辑器详解

vi/vim &#xff1a; 强大的编辑器 进入vi的命令 vi filename :打开或新建文件&#xff0c;并将光标置于第一行首 vi n filename &#xff1a;打开文件&#xff0c;并将光标置于第n行首 vi filename &#xff1a;打开文件&#xff0c;并将光标置于最后一行首 vi /pattern …

linux 定义快捷命令,Linux系统自定义快捷命令的详细说明

Linux系统用户可以自定义喜欢的快捷键命令。下面由学习啦小编为大家整理了Linux系统自定义快捷键命令的详细说明&#xff0c;希望对大家有帮助!Linux系统自定义快捷命令的详细说明目前总结到的有两种方式&#xff0c;一种是临时快捷键&#xff0c;一种是永久快捷键。Linux系统自…

python求最小公倍数_python求最大公约数和最小公倍数的简单方法

python怎么求最大公约数和最小公倍数 一、求最大公约数 用辗转相除法求最大公约数的算法如下&#xff1a; 两个正整数a和b&#xff08;a>b&#xff09;&#xff0c;它们的最大公约数等于a除以b的余数c和b之间的最大公约数。比如10和25&#xff0c;25除以10商2余5&#xff0c…

linux如何获取raw中的文件路径,如何使用Linux获取Touchscreen Rawdata的坐标

我们有一个3米的微触摸显示屏.它通过usb连接到我的debian系统,并被识别为人机界面(hid).我正在尝试访问并推送实时信息…如果它被触及我想知道哪里(x,y)并通过netcat管道到另一台主机.不幸的是,我只能使用原始数据cat /dev/input/event2 | hexdump要么evtest你得到的hexcode似乎…

实验三+067+冯艳芳

一、实验目的 掌握黑盒测试用例设计方法 二、实验要求 &#xff08;1&#xff09;对被测程序进行黑盒测试用例设计 &#xff08;2&#xff09;运用等价类、边界值、决策表、状态图法等进行测试用例设计。 &#xff08;3&#xff09;对手机上任意一款音乐软件进行黑盒测试实践。…

python越来越慢_为什么Python中的串联速度越来越慢?

为什么在某些情况下,Python 3中的连接似乎比Python 2中的连接慢&#xff1f; 影响最大的串联方法似乎是字节对象的连续串联,从O(n)到O(n?)操作. 我的分析代码大部分在这里&#xff1a; #!/usr/bin/env python from operator import concat from sys import version, version_i…