NPOI导出Excel设置单元高度自适应

 public class ExcelAHelper
    {
        /// 
        /// List转Excel
        /// 
        /// 
        /// 
        /// 
        /// 
        /// 
        public static byte[] Export(IList list, IList dicts, string SheetName = "Sheet1")
        {
            IWorkbook book = new XSSFWorkbook();

            //单元格字体和样式
            ICellStyle styleCell = book.CreateCellStyle();
            styleCell.Alignment = HorizontalAlignment.Center;
            styleCell.WrapText = true;
            styleCell.BorderTop = BorderStyle.Thin;
            styleCell.BorderRight = BorderStyle.Thin;
            styleCell.BorderLeft = BorderStyle.Thin;
            styleCell.BorderBottom = BorderStyle.Thin;
            styleCell.Alignment = HorizontalAlignment.Center;
            IFont font = book.CreateFont();
            font.FontHeightInPoints = 10;
            font.FontName = "微软雅黑";
            styleCell.SetFont(font);
            ISheet sheet = book.CreateSheet(SheetName);
            IRow row = sheet.CreateRow(0);
            row.RowStyle = styleCell;
            for (int i = 0; i < dicts.Count; i++)
            {
                row.CreateCell(i).SetCellValue(dicts[i].ColumnName);
                sheet.SetColumnWidth(i, dicts[i].Width * 256);
                sheet.SetDefaultColumnStyle(i, styleCell);
            }
            for (int i = 0; i < list.Count; i++)
            {
                var entity = list[i];
                IRow mRow = sheet.CreateRow(i + 1);
                for (int j = 0; j < dicts.Count; j++)
                {
                    var property = typeof(T).GetProperty(dicts[j].PropertyName);
                    if (property != null)
                    {
                        mRow.CreateCell(j).SetCellValue(property.GetValue(entity) == null ? "" : property.GetValue(entity).ToString());
                        mRow.RowStyle = styleCell;
                    }

                }
            }

            // 写入到客户端    
            MemoryStream ms = new MemoryStream();
            book.Write(ms);
            ms.Flush();



            return ms.ToArray();
        }

        public static byte[] ExportByGroup(IEnumerable> datas, IList columns)
        {
            IWorkbook book = new XSSFWorkbook();

            //单元格字体和样式
            ICellStyle styleCell = book.CreateCellStyle(); 
            styleCell.Alignment = HorizontalAlignment.Center;
            styleCell.WrapText = true;
            styleCell.BorderTop = BorderStyle.Thin;
            styleCell.BorderRight = BorderStyle.Thin;
            styleCell.BorderLeft = BorderStyle.Thin;
            styleCell.BorderBottom = BorderStyle.Thin;
            styleCell.VerticalAlignment = VerticalAlignment.Distributed; 
            styleCell.Alignment = HorizontalAlignment.Center;
            IFont font = book.CreateFont();
            font.FontHeightInPoints = 10;
            font.FontName = "微软雅黑"; 
            styleCell.SetFont(font);


            foreach (var item in datas)
            {
                var sheet = book.CreateSheet(item.Key); 
                IRow row = sheet.CreateRow(0);
                row.RowStyle = styleCell;
                for (int i = 0; i < columns.Count; i++)
                {
                    row.CreateCell(i).SetCellValue(columns[i].ColumnName);
                    sheet.SetColumnWidth(i, columns[i].Width * 256); 
                    sheet.VerticallyCenter = true; 
                    sheet.SetDefaultColumnStyle(i, styleCell);
                }

                for (int i = 0; i < item.Count(); i++)
                {
                    var entity = item.ToList()[i];
                    IRow mRow = sheet.CreateRow(i + 1);
                    mRow.RowStyle=styleCell;
                    for (int j = 0; j < columns.Count; j++)
                    {
                        var property = typeof(T).GetProperty(columns[j].PropertyName);
                        if (property != null)
                        {
                            ICell cell = mRow.CreateCell(j);
                            
                            cell.SetCellValue(property.GetValue(entity) == null ? "" : HttpUtility.UrlDecode(property.GetValue(entity).ToString()).Replace("&", "&").Replace("<", "<").Replace(">", ">").Replace(""", "\"").Replace("'", "'"));
                            cell.CellStyle = styleCell;
                        } 
                         
                    }

                }

            }
            MemoryStream ms = new MemoryStream();
            book.Write(ms);
            ms.Flush();  
            return ms.ToArray();
        }

        public static void Bytes2File(byte[] buff, string savepath)
        {
            if (File.Exists(savepath))
            {
                File.Delete(savepath);
            }

            FileStream fs = new FileStream(savepath, FileMode.CreateNew);
            BinaryWriter bw = new BinaryWriter(fs);
            bw.Write(buff, 0, buff.Length);
            bw.Close();
            fs.Close();
        }

    }


    public class ExcelEntity
    {
        /// 
        /// 列名
        /// 
        public string ColumnName { get; set; }
        /// 
        /// 属性名
        /// 
        public string PropertyName { get; set; }
        /// 
        ///宽度
        /// 
        public int Width { get; set; }
    }

 

你可能感兴趣的:(.Net)