python list写入excel_写一个通用的List集合导出excel的通用方法|python基础教程|python入门|python教程...

发布于:2023-04-27 ⋅ 阅读:(243) ⋅ 点赞:(0)

https://www.xin3721.com/eschool/pythonxin3721/

我就打算写一个通用的。

这样一来用的时候也方便,数据主要是通过Orm取的List。这样写一个通用的刚好。

public static void ListToExcel(List ts, string[] RowName, string[] ListCorrespondRow, bool IsRowName = false)//创建工作簿对象 newHSSFWorkbook();//创建工作表 "onesheet");= sheet.CreateRow(0); for (int i = 0; i < RowName.Length; i++)for (int r = 1; r <= ts.Count; r++)//创建行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每一列赋值的时候需要传索引号。

92463ce7634ac793dc8c8c9c367a826f.png

我也就是我单独把他拉出来的原因。

9375b296f047ba057523775f8ef341f0.png

7503554fef794ea48ca0716b8058dbb3.png

但是这样用循环依次获取属性的值会出问题,会报错。

bc0ed21543d1676dc04e229a4bce60ce.png

然后我只得用这个方法了。用这样的话,还需要自己定义一个数组把当前对象有字段的名称告诉这个方法,所以略显麻烦,所以之前一直在搞不要输入的按照顺序直接赋值的。但是没弄出来:)

之所以能用这个方法是因为把对象转成json在把json转成对象后这个对象是Jobject 就是Newtonsoft.Json里面的一个东西。他支持用【】来获取数据

dynamic是不支持【】获取属性的值的。

还有就是SetCellValue不加Convert.ToString有时候会报错,报具有二义性,我F12看了一下源码,

82323299ce0be138a0d0b5fa381560e7.png

应该是这两个有点小差异,所以转换一下就好了

98a23c57e1489b2a200a785d211e982c.png

与用法就是这个样子的

__EOF__

2cd33cd6b7d41cfeb9e022e6646afe7d.png

本文作者:沉_默