首页 > temp > 简明python教程 >
-
写一个通用的List集合导出excel的通用方法
我就打算写一个通用的。
这样一来用的时候也方便,数据主要是通过Orm取的List。这样写一个通用的刚好。
在写这个的时候就遇到了一些问题。
刚开始是打算用反射进去获取,因为刚开始我自己试了一下(我手动创建了一个list集合里面的对象也是自己手动输入的)
这个时候用
这串代码来往excel里面插入是没有问题的。
但是后来发现我自己创建的list和数据库查询之后返回的list不一样。
我数据库框架用的dapper,接受集合的时候用的是List<dynamic>
这时候就用反射获取不到有多少个属性了,也就取不到值了。
后来我想既然这样我就把他转成json在把他转成dynamic。
后来试了一下,果然可以获取的到属性长度的数组。
但是不能用foreach,因为这样会出错,给excel每一列赋值的时候需要传索引号。
我也就是我单独把他拉出来的原因。
但是这样用循环依次获取属性的值会出问题,会报错。
然后我只得用这个方法了。用这样的话,还需要自己定义一个数组把当前对象有字段的名称告诉这个方法,所以略显麻烦,所以之前一直在搞不要输入的按照顺序直接赋值的。但是没弄出来:)
之所以能用这个方法是因为把对象转成json在把json转成对象后这个对象是Jobject 就是Newtonsoft.Json里面的一个东西。他支持用【】来获取数据
dynamic是不支持【】获取属性的值的。
还有就是SetCellValue不加Convert.ToString有时候会报错,报具有二义性,我F12看了一下源码,
应该是这两个有点小差异,所以转换一下就好了
与用法就是这个样子的
__EOF__