• 写入数据到Excel


    ---------------------DownloadExcelAsStreame<T>(IList<T> param, string sheetname=null) where T : new()------------------

    依赖:

      |-NPOI

      |-Newtonsoft

    备注:

    这里为了方便,么有自己定义Attribute,用Josn的Attribute来给类型带入参数。

    注意:

    这个版本的NPOI写入Excel,单个文件最多只能写入65536行,如果不满足需要可以转写入CVS(CVS不限制大小)

    --------------------------------------------------------------------------------------------------------------------------------

     1  public static MemoryStream DownloadExcelAsStreame<T>(IList<T> param, string sheetname=null) where T : new()
     2  {
     3       if (param == null || param.Count < 1)
     4                 return null;
     5             int rowsCount = param.Count(),columnCount = param.FirstOrDefault().GetType().GetProperties().Count(p => p.PropertyType.IsPublic);
     6             var tp= typeof (T);
     7             var tpattr = tp.GetCustomAttribute<JsonObjectAttribute>();
     8             if (tpattr == null)
     9                 return null;
    10             HSSFWorkbook workbook = new HSSFWorkbook();
    11             HSSFSheet sheet = workbook.CreateSheet(sheetname?? tpattr.Id) as HSSFSheet;
    12             HSSFRow headerRow = sheet.CreateRow(0) as HSSFRow;
    13             List<PropertyInfo> pts = tp.GetProperties().Where(p => p.PropertyType.IsPublic).Select(o => o).ToList();
    14             string[] atv = pts.ConvertAll(ii =>
    15             {
    16                 var jsonPropertyAttribute = ii.GetCustomAttribute<JsonPropertyAttribute>();
    17                 if (jsonPropertyAttribute != null)
    18                     return jsonPropertyAttribute.PropertyName;
    19                 return string.Empty;
    20             }).ToArray();
    21             var me = new MemoryStream();
    22             int paddingrow = 0;
    23             int rowindex = 0;
    24             for (int nn = 0; nn < columnCount; nn++)
    25             {
    26                 if (!string.IsNullOrEmpty(atv[nn]))
    27                 {
    28                     headerRow.CreateCell(rowindex, NPOI.SS.UserModel.CellType.String).SetCellValue(atv[nn] ?? pts[nn].Name);
    29                     rowindex++;
    30                 }
    31             }
    32             paddingrow += 1;
    33             rowindex = 0;
    34             for (int r = 0; r < rowsCount; r++)
    35             {
    36                 HSSFRow cntRow = sheet.CreateRow(r + paddingrow) as HSSFRow;
    37                 for (int pj = 0; pj < columnCount; pj++)
    38                 {
    39                     if (!string.IsNullOrEmpty(atv[pj]))
    40                     {
    41                         cntRow.CreateCell(rowindex, NPOI.SS.UserModel.CellType.String)
    42                             .SetCellValue(pts[pj].GetValue(param[r]) != null
    43                                 ? pts[pj].GetValue(param[r]).ToString()
    44                                 : "");
    45                         rowindex++;
    46                     }
    47                 }
    48                 rowindex =0;
    49             }
    50             workbook.Write(me);
    51             workbook.Close();
    52             return me;
    53         }
  • 相关阅读:
    结构型模式(一) 适配器模式
    选择器
    CSS引入
    CSS语法
    CSS介绍
    HTML练习
    HTML标签嵌套规则(重点)
    HTML标签分类(重点)
    HTML标签属性
    body标签
  • 原文地址:https://www.cnblogs.com/Thancoo/p/bulkWriteToExcel.html
Copyright © 2020-2023  润新知