关于我们

质量为本、客户为根、勇于拼搏、务实创新

< 返回新闻公共列表

云南大王-写一个通用的List集合导出excel的通用方法

发布时间:2020-04-16 00:00:00
前几天要做一个数据导出Excel  我就打算写一个通用的。 这样一来用的时候也方便,数据主要是通过Orm取的List。这样写一个通用的刚好。 public static void ListToExcel(List ts, string[] RowName, string[] ListCorrespondRow, bool IsRowName = false) { //创建工作簿对象 IWorkbook workbook = new HSSFWorkbook(); //创建工作表 ISheet sheet = workbook.CreateSheet("onesheet"); IRow row0 = sheet.CreateRow(0); for (int i = 0; i < RowName.Length; i++) { row0.CreateCell(i).SetCellValue(RowName[i]); } for (int r = 1; r <= ts.Count; r++) { //创建行row IRow row = sheet.CreateRow(r); dynamic tsc = ts[r-1];string sJson = JsonConvert.SerializeObject(tsc); dynamic sObj = JsonConvert.DeserializeObject(sJson); var sObjLen = sObj.GetType().GetProperties(); for (int j = 0; j < ListCorrespondRow.Length; j++) { //通过【】来取值 但必须要通过json转成的对象才可以这样取 row.CreateCell(j).SetCellValue(Convert.ToString(sObj[ListCorrespondRow[j]])); } //foreach (System.Reflection.PropertyInfo p in tsc.GetType().GetProperties()) //{ // //row.CreateCell().SetCellValue(p.GetValue(tsc)); //} //for (int j = 0; j < sObjLen.Length; j++) //{ //利用反射将对象里面的值添加到excel里面 添加的顺序是按照对象里面字段的顺序 注意和列名保持一致 // row.CreateCell(j).SetCellValue(sObjLen[j].GetValue(tsc)); //} } //创建流对象并设置存储Excel文件的路径 using (FileStream url = File.OpenWrite(@"C:/Users/13002/source/repos/练习/练习/WordDot/test3.xls")) { //导出Excel文件 workbook.Write(url); //Response.Write(""); }; ////workbook.Write(); ////创建文件流 //MemoryStream bookStream = new MemoryStream(); ////文件写入流(向流中写入字节序列) //workbook.Write(bookStream); ////输出之前调用Seek(偏移量,游标位置) 把0位置指定为开始位置 //bookStream.Seek(0, SeekOrigin.Begin); //return bookStream; }   在写这个的时候就遇到了一些问题。   刚开始是打算用反射进去获取,因为刚开始我自己试了一下(我手动创建了一个list集合里面的对象也是自己手动输入的)   这个时候用 foreach (System.Reflection.PropertyInfo p in tsc.GetType().GetProperties()) { row.CreateCell().SetCellValue(p.GetValue(tsc)); }   这串代码来往excel里面插入是没有问题的。   但是后来发现我自己创建的list和数据库查询之后返回的list不一样。   我数据库框架用的dapper,接受集合的时候用的是List   这时候就用反射获取不到有多少个属性了,也就取不到值了。   后来我想既然这样我就把他转成json在把他转成dynamic。   后来试了一下,果然可以获取的到属性长度的数组。   但是不能用foreach,因为这样会出错,给excel每一列赋值的时候需要传索引号。       我也就是我单独把他拉出来的原因。       但是这样用循环依次获取属性的值会出问题,会报错。           然后我只得用这个方法了。用这样的话,还需要自己定义一个数组把当前对象有字段的名称告诉这个方法,所以略显麻烦,所以之前一直在搞不要输入的按照顺序直接赋值的。但是没弄出来:)   之所以能用这个方法是因为把对象转成json在把json转成对象后这个对象是Jobject 就是Newtonsoft.Json里面的一个东西。他支持用【】来获取数据   dynamic是不支持【】获取属性的值的。   还有就是SetCellValue不加Convert.ToString有时候会报错,报具有二义性,我F12看了一下源码,              应该是这两个有点小差异,所以转换一下就好了         与用法就是这个样子的

相关阅读

js 判断手机版与PC版自适应跳转C#截取字符串的方法C# 中使用正则表达式验证手机号、身份证号码强制性修改div框里出现的css值VS2017调试代码显示“当前无法命中断点,还没有为该文档加载任何符号”js获取当前域名、Url、相对路径和参数以及指定参数JavaScript数组整理C# 对象和类型总结关于javascript跳转与返回和刷新页面Express中的中间件简介及用法JS的原型和继承webstorm的 Emmet 快捷方式什么是Redis缓存的雪崩、击穿、穿透Cookie的基本介绍和场景Vue.js中keep-alive缓存(页面+滚动条)HTML5在客户端是如何存储数据的?MySQL中多表操作有哪些?Cookie与Session的认识使用集合组织相关数据深入C#数据类型c#中的委托简单认识.NET框架密码学系列——常见的加密方式有哪些.NET 异步详解线程池的五种实现方式centos7系统中忘记了root管理员账号密码的解决方式公司管理必须的20条军规[参考]云南昆明天猫旗舰店如何开_怎么开_要什么条件云南大王-通俗理解spring源码(三)—— 获取xml的验证模式 云南大王-用户登录 云南大王-【Golang进阶】指针的详细讲解 云南大王-Java 单线程代码ThreadLocal串值问题 云南大王-Java 实例级别的锁和类级别的锁 云南大王-工作流引擎会签,加签,主持人,组长模式专题讲解 云南大王-Android连载5云南大王-NTP对时器(NTP对时服务器)重要性!京准电子科技 云南大王-关于redis单线程的分析 云南大王-CVE云南大王-PHP SESSION反序列化本地样例分析 云南大王-这不就是多线程ThreadPoolExecutor和阻塞队列吗 云南大王-Tomcat AJP 文件包含漏洞(CVE云南大王-讲真,这两款idea插件,能治愈你英语不好的病 云南大王-消息中间件ActiveMQ、RabbitMQ、RocketMQ、ZeroMQ、Kafka如何选型? 云南大王-JVM系列十三(类加载器). 云南大王-Win10安装MySQL8压缩包版 云南大王-初始WebApi(2) 云南大王-初识人工智能(二):机器学习(一):sklearn特征抽取 云南大王-Popup中ListBox的SelectChange事件关闭弹出窗体后主窗体点击无效BUG 云南大王-基础知识记录 云南大王-FastDFS搭建图片服务器 云南大王-git/sourcetree解决本地仓库历史合并到线上仓的历史数据合并问题_refusing to merge unrelated histories 云南大王-js判断字符是否在数组中【转】 云南大王-Python 云南大王-面向对象之多线程(可捎带电梯调度) 云南大王-Python练习题2.5求奇数分之一序列前N项和(存在问题) 云南大王-React 中的前端路由 react云南大王-VSCODE 远程开发树莓派 云南大王-React新闻网站云南大王-vs .net CS0006 C# 未能找到元数据文件 .dll 云南大王-Vue.js 技术揭秘 云南大王-流程控制语句云南大王-Python学习笔记:Python的时间操作(time,datetime,timedelta,calendar) 云南大王-流程控制语句云南大王-golang Gin framework with websocket 云南大王-多重判断if..else嵌套语句 云南大王-用户登录 云南大王-流程控制语句云南大王-密码类 云南大王-Unity2018发布WebGL注意事项总结 云南大王-web系统安全运营之基础云南大王- 流程控制语句云南大王-中型WPF客户端开发项目总结(3.3.4) 云南大王-流程控制语句云南大王-流程控制语句云南大王-流程控制语句云南大王-中型WPF客户端开发项目总结(4) 云南大王-流程控制语句云南大王-ASP.NET Core笔记(4) 云南大王-C# 基础知识系列云南大王-让 .NET 轻松构建中间件模式代码(二) 云南大王-基于 HTML5 WebGL 的 水泥工厂可视化系统 云南大王-.NET Core 3 WPF MVVM框架 Prism系列之导航系统 云南大王-《JavaScript异步编程》精读笔记 云南大王-合理使用CSS框架,加速UI设计进程 云南大王-CLSID 为 {000209FF云南大王-从零基础转行到前端大牛,需要经过哪几个阶段? 云南大王-一个简单的例子看明白 async await Task 云南大王-【目前】宇宙第一IDE Visual Studio 合并压缩css、js扩展组件云南大王-写一个通用的List集合导出excel的通用方法 云南大王-Bootstrap4 按钮组+徽章(Badges)+进度条+分页+列表组 云南大王-Web前端工程师需要学些什么? 云南大王-react嵌套路由 云南大王-【java框架】Struts2(2) 云南大王-javaSE笔记云南大王-.net core 集成 sentry 进行异常报警 云南大王-Java の 四种引用 云南大王-JVM 虚拟机&&类加载(一) 云南大王-使用Fastjson实现JSON与JavaBean之间互相转换 云南大王-Python操作Oracle数据库:cx_Oracle 云南大王-为什么要用内插字符串代替string.format
/template/Home/Zkeys/PC/Static