当前位置: 首页 > news >正文

完整教程:C#.NetCore NPOI 导出excel 单元格内容换行

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

在NPOI中实现Excel单元格内容换行,可经过以下手段建立,本文介绍代码,仅供参考。

方法介绍

‌1、设置自动换行样式‌

通过ICellStyle.WrapText = true属性开启单元格自动换行功能,同时建议设置对齐方式为居中以优化显示效果。

‌2、处理换行符‌

若内容含\n换行符,需确保单元格样式已启用自动换行,否则换行符会展示为空格。

对于HTML换行符<br>,可先替换为\n再赋值给单元格。

‌3、调整行高‌

自动换行后需手动调整行高以适应内容,可经过row.HeightInPoints属性设置(如原高度的2倍)。

C#示例代码如下:

using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;

public class ExcelExporter
{
public void ExportWithWrapText(string filePath)
{
// 创建工作簿
IWorkbook workbook = new XSSFWorkbook();
ISheet sheet = workbook.CreateSheet("Sheet1");

// 创建带换行样式
ICellStyle wrapStyle = workbook.CreateCellStyle();
wrapStyle.WrapText = true; // 关键设置
wrapStyle.Alignment = HorizontalAlignment.Center;
wrapStyle.VerticalAlignment = VerticalAlignment.Center;

// 创建行并设置内容
IRow row = sheet.CreateRow(0);
ICell cell = row.CreateCell(0);
cell.SetCellValue("第一行文本\n第二行文本"); // 使用\n换行
cell.CellStyle = wrapStyle;

// 调整行高
row.HeightInPoints = 2 * sheet.DefaultRowHeightInPoints;

// 保存文件
using (FileStream fs = new FileStream(filePath, FileMode.Create))
{
workbook.Write(fs);
}
}
}


4、完成要点说明

必须同时设置WrapText和行高才能正确显示多行内容。

支持依据程序生成的换行符或用户输入的ALT+ENTER换行符。

若内容来自HTML,需先将<br>转换为\n再赋值。

5、完整C# .NetCore 示例代码

using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;

public class ExcelExporter
{
public void ExportWithWrapText(string filePath)
{
IWorkbook workbook = new XSSFWorkbook();
ISheet sheet = workbook.CreateSheet("Sheet1");

// 创建带换行样式
ICellStyle wrapStyle = workbook.CreateCellStyle();
wrapStyle.WrapText = true; // 关键设置
wrapStyle.Alignment = HorizontalAlignment.Center;
wrapStyle.VerticalAlignment = VerticalAlignment.Center;

// 创建行并设置内容
IRow row = sheet.CreateRow(0);
ICell cell = row.CreateCell(0);
cell.SetCellValue("第一行文本\n第二行文本"); // 使用\n换行
cell.CellStyle = wrapStyle;

// 调整行高
row.HeightInPoints = 2 * sheet.DefaultRowHeightInPoints;

// 保存材料
using (FileStream fs = new FileStream(filePath, FileMode.Create))
{
workbook.Write(fs);
}
}
}

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

http://www.hskmm.com/?act=detail&tid=10432

相关文章:

  • resultMap和resultType
  • 直播软件怎么开发,自适应两栏布局方式 - 云豹科技
  • resultMap和自定义映射结果形式(ResultMapManage)以及ResultMap Vs ResultType
  • 嵌入式设备不能正常上网问题
  • 2、论文固定模板(背景过度结尾)
  • go: 图片文件上传
  • go: 生成缩略图
  • git: 报错: fatal: 协议错误:错误的行长度字符串:This 或 fatal: protocol error: bad line length character: This
  • jquery: Justified gallery
  • 安装crmeb
  • gin: 用zap记录访问日志
  • gin: 打包模板文件、静态文件到二进制文件中
  • gin: 判断是否ajax请求
  • gin: 静态文件
  • 详细介绍:【论文精读】基于YOLOv3算法的高速公路火灾检测
  • MacOS 下fuzz学习踩坑点
  • An Empirical Study on Commit Message Generation using LLMs via In-Context Learning 论文笔记
  • 实用指南:人工智能学习:Transformer结构中的编码器层(Encoder Layer)
  • vcpkg 安装依赖
  • Java03课前问题列表
  • JavaScript错误处理完全指南:从基础到自定义错误实战
  • 1、论文准备
  • PION 游击
  • Web3 开发者修炼全图谱:从 Web2 走向 Web3 的实用的系统性学习指南
  • 实用指南:医院高值耗材智能化管理路径分析(下)
  • Flutter应用自动更新系统:生产环境的挑战与解决方案
  • .NET Core中使用SignalR
  • 实用指南:修复Conda连接异常:CondaHTTPError HTTP 000 CONNECTION FAILED故障排除指南
  • 高级数据结构手册
  • Tarjan 学习笔记