C# 设置Excel中文本的对齐方式、换行、和旋转

news2025/4/15 14:38:29

在 Excel 中,对齐、换行和旋转是用于设置单元格内容显示方式的功能。合理的设置这些文本选项可以帮助用户更好地组织和展示 Excel 表格中的数据,使表格更加清晰、易读,提高数据的可视化效果。本文将介绍如何在.NET 程序中通过C# 设置Excel单元格中文本的对齐方式、方向以及换行。

安装所需.NET库

本文需要用到一个名为 Free Spire.XLS for .NET 的免费国产库。该库支持多种Excel文档操作功能,包括生成、读取、编辑、打印、转换等。

该库可以直接通过Visual Studio > NuGet程序包管理器中搜索 “FreeSpire.XLS” 来安装。也可以通过该链接下载产品包后手动添加引用。

C# 设置Excel中文本的对齐方式、方向以及换行

免费Spire.XLS库的 CellStyle 类提供了多种属性来设置单元样式包括其中的文本对齐。旋转等。具体步骤参考:

  1. 创建一个Excel工作簿并获取其中指定工作表。
  2. 通过 Worksheet.Range[] 属性获取指定单元格或单元格范围
  3. 通过 CellRange.Style 属性获取单元格样式。
  4. 通过 CellStyle.HorizontalAlignment 属性设置单元格中文字的水平对齐方式,包括左对齐(HorizontalAlignType.Left)、水平居中对齐(HorizontalAlignType.Center)、和右对齐(HorizontalAlignType.Right)。
  5. 通过 CellStyle.VerticalAlignment 属性设置单元格中文字的垂直对齐方式,包括靠上对齐(VerticalAlignType.Top)、垂直居中对齐(VerticalAlignType.Center)、和靠下对齐(VerticalAlignType.Bottom)。
  6. 通过 CellStyle.Rotation 属性旋转单元格中的文字旋转至指定角度。
  7. 通过 CellStyle.WrapText 属性设置文本自动换行,手动换行可以添加换行符\n
  8. 保存生成文件。

C#代码:

using Spire.Xls;

namespace SetExcelColumnWidth
{
    class Program
    {

        static void Main(string[] args)
        {
            // 创建工作簿
            Workbook wookbook = new Workbook();

            // 获取第一张工作表
            Worksheet sheet = wookbook.Worksheets[0];

            // 添加说明文字
            sheet.Range["B1"].Text = "文字对齐方式";
            sheet.Range["D1"].Text = "文字方向";
            sheet.Range["F1"].Text = "文字换行";
            sheet.Range["B1:F1"].Style.Font.IsBold = true;
            sheet.Range["B1:F1"].Style.KnownColor = ExcelColors.LightGreen;

            // 左对齐
            sheet.Range["B3"].Text = "左对齐";
            sheet.Range["B3"].Style.HorizontalAlignment = HorizontalAlignType.Left;

            // 水平居中
            sheet.Range["B4"].Text = "水平居中";
            sheet.Range["B4"].Style.HorizontalAlignment = HorizontalAlignType.Center;

            // 右对齐
            sheet.Range["B5"].Text = "右对齐";
            sheet.Range["B5"].Style.HorizontalAlignment = HorizontalAlignType.Right;

            // 居上
            sheet.Range["B7"].Text = "靠上";
            sheet.Range["B7"].Style.VerticalAlignment = VerticalAlignType.Top;

            // 垂直居中
            sheet.Range["B8"].Text = "垂直居中";
            sheet.Range["B8"].Style.VerticalAlignment = VerticalAlignType.Center;

            // 居下
            sheet.Range["B9"].Text = "靠下";
            sheet.Range["B9"].Style.VerticalAlignment = VerticalAlignType.Bottom;

            // 分散对齐并居中
            sheet.Range["B10"].Text = "水平分散对齐+垂直居中";
            sheet.Range["B10"].Style.HorizontalAlignment = HorizontalAlignType.Distributed;
            sheet.Range["B10"].Style.VerticalAlignment = VerticalAlignType.Center;

            // 逆时针旋转45°
            sheet.Range["D7"].Text = "旋转45°";
            sheet.Range["D7"].Style.Rotation = 45;

            // 逆时针旋转90°
            sheet.Range["D8"].Text = "旋转90°";
            sheet.Range["D8"].Style.Rotation = 90;

            // 顺时针旋转45°
            sheet.Range["D9"].Text = "旋转-45°";
            sheet.Range["D9"].Style.Rotation = -45;

            // 顺时针旋转90°
            sheet.Range["D10"].Text = "旋转-90°";
            sheet.Range["D10"].Style.Rotation = -90;

            // 添加‘\n’进行文字换行
            sheet.Range["F8"].Text = "这是\n手动\n换行";

            // 自动换行
            sheet.Range["F9"].Text = "这一段话设置了自动换行";
            sheet.Range["F9"].Style.WrapText = true;

            // 设置行高列宽
            sheet.Columns[1].ColumnWidth = 15;
            sheet.Columns[3].ColumnWidth = 15;
            sheet.Columns[5].ColumnWidth = 15;
            sheet.Range["B3:B5"].RowHeight = 15;
            sheet.Range["B7:B10"].RowHeight = 50;

            // 保存文档
            wookbook.SaveToFile("Excel文本对齐.xlsx", FileFormat.Version2013);
        }
    }
}

生成文档:
Excel文字对齐、旋转、换行


Spire.XLS 库的API参考:
https://www.e-iceblue.com/apireference/net/Spire.XLS/html/N_Spire_Xls.htm

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2334228.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RPA VS AI Agent

图片来源网络 RPA(机器人流程自动化)和AI Agent(人工智能代理)在自动化和智能化领域各自扮演着重要角色,但它们之间存在显著的区别。以下是对两者区别的详细分析: 一、定义与核心功能 RPA(机…

uniapp大文件分包

1. 在pages.json中配置 "subPackages":[{"root":pagesUser,"pages":[{"path":mine/xxx,"style":xxx },{"path":mine/xxx,"style":xxx}]},{"root":pagesIndex,"pages":[{"p…

Spark-core编程

sortByKey 函数说明 join 函数说明 leftOuterJoin 函数说明 cogroup 函数说明 RDD行动算子: 行动算子就是会触发action的算子,触发action的含义就是真正的计算数据。 reduce 函数说明 collect 函数说明 foreach 函数说明 count 函数说明 first …

2025年的Android NDK 快速开发入门

十年前写过一篇介绍NDK开发的文章《Android实战技巧之二十三:Android Studio的NDK开发》,今天看来已经发生了很多变化,NDK开发变得更加容易了。下面就写一篇当下NDK开发快速入门。 **原生开发套件 (NDK) **是一套工具,使开发者能…

基于springboot的“嗨玩旅游网站”的设计与实现(源码+数据库+文档+PPT)

基于springboot的“嗨玩旅游网站”的设计与实现(源码数据库文档PPT) 开发语言:Java 数据库:MySQL 技术:springboot 工具:IDEA/Ecilpse、Navicat、Maven 系统展示 系统功能结构图 局部E-R图 系统首页界面 系统注册…

React 之 Redux 第三十一节 useDispatch() 和 useSelector()使用以及详细案例

使用 Redux 实现购物车案例 由于 redux 5.0 已经将 createStore 废弃,我们需要先将 reduxjs/toolkit 安装一下; yarn add reduxjs/toolkit// 或者 npm install reduxjs/toolkit使用 vite 创建 React 项目时候 配置路径别名 : // 第一种写法…

Llama 4全面评测:官方数据亮眼,社区测试显不足之处

引言 2025年4月,Meta正式发布了全新的Llama 4系列模型,这标志着Llama生态系统进入了一个全新的时代。Llama 4不仅是Meta首个原生多模态模型,还采用了混合专家(MoE)架构,并提供了前所未有的上下文长度支持。本文将详细介绍Llama 4…

【C++】函数直接返回bool值和返回bool变量差异

函数直接返回bool值和返回bool变量差异 背景 在工作中遇到一个比较诡异的问题,场景是给业务方提供的SDK有一个获取状态的函数GetStatus,函数的返回值类型是bool,在测试过程中发现,SDK返回的是false,但是业务方拿到的…

第1节:计算机视觉发展简史

计算机视觉与图像分类概述:计算机视觉发展简史 计算机视觉(Computer Vision)作为人工智能领域的重要分支,是一门研究如何使机器"看"的科学,更具体地说,是指用摄影机和计算机代替人眼对目标进行识…

英伟达Llama-3.1-Nemotron-Ultra-253B-v1语言模型论文快读:FFN Fusion

FFN Fusion: Rethinking Sequential Computation in Large Language Models 代表模型:Llama-3.1-Nemotron-Ultra-253B-v1 1. 摘要 本文介绍了一种名为 FFN Fusion 的架构优化技术,旨在通过识别和利用自然并行化机会来减少大型语言模型(LLM…

云曦月末断网考核复现

Web 先看一个BUUCTF中的文件一个上传题 [BUUCTF] 2020新生赛 Upload 打开后是一个文件上传页面 随便上传一个txt一句话木马后出现js弹窗,提示只能上传图片格式文件 说明有前端验证。我的做法是把一句话改为.jpg格式, 然后上传 访问发现虽然上传成功了…

Flutter常用组件实践

Flutter常用组件实践 1、MaterialApp 和 Center(组件居中)2、Scaffold3、Container(容器)4、BoxDecoration(装饰器)5、Column(纵向布局)及Icon(图标)6、Column/Row(横向/横向布局)+CloseButton/BackButton/IconButton(简单按钮)7、Expanded和Flexible8、Stack和Po…

0.机器学习基础

0.人工智能概述: (1)必备三要素: 数据算法计算力 CPU、GPU、TPUGPU和CPU对比: GPU主要适合计算密集型任务;CPU主要适合I/O密集型任务; 【笔试问题】什么类型程序适合在GPU上运行&#xff1…

系统与网络安全------网络通信原理(4)

资料整理于网络资料、书本资料、AI,仅供个人学习参考。 网络层解析 IP 网络层概述 位于OSI模型第三层作用 定义网络设备的逻辑地址,俗称网络层地址(如IP地址) 在不同的网段之间选择最佳数据转发路径 协议 IP协议 IP数据包…

Java基础 4.12

1.方法的重载(OverLoad) 基本介绍 Java中允许同一个类,多个同名方法的存在,但要求形参列表不一致! 如 System.out.println(); out是PrintStream类型 重载的好处 减轻了起名的麻烦减轻了记名的麻烦 2.重载的快速入…

XILINX DDR3专题---(1)IP核时钟框架介绍

1.什么是Reference Clock,这个时钟一定是200MHz吗? 2.为什么APP_DATA是128bit,怎么算出来的? 3.APP :MEM的比值一定是1:4吗? 4.NO BUFFER是什么意思? 5.什么情况下Reference Clock的时钟源可…

clickhouse注入手法总结

clickhouse 遇到一题clickhouse注入相关的,没有见过,于是来学习clickhouse的使用,并总结相关注入手法。 环境搭建 直接在docker运行 docker pull clickhouse/clickhouse-server docker run -d --name some-clickhouse-server --ulimit n…

React 组件样式

在这里插入图片描述 分为行内和css文件控制 行内 通过CSS中类名文件控制

利用 pyecharts 实现地图的数据可视化——第七次人口普查数据的2d、3d展示(关键词:2d 、3d 、map、 geo、涟漪点)

参考文档:链接: link_pyecharts 官方文档 1、map() 传入省份全称,date_pair 是列表套列表 [ [ ],[ ] … ] 2、geo() 传入省份简称,date_pair 是列表套元组 [ ( ),( ) … ] 1、准备数据 population_data:简称经纬度 population_da…

解决 Elasticsearch 分页查询性能瓶颈——从10分钟到秒级的优化实践

大家好,我是铭毅天下,一名专注于 Elasticsearch (以下简称ES)技术栈的技术爱好者。 今天我们来聊聊球友提出的一个实际问题: ES分页查询性能很差,使用from/size方式检索居然需要10分钟! 这是一个…