.NET使用C#设置Excel单元格数值格式

 更新时间:2024年12月15日 15:02:09   作者:Eiceblue  
这篇文章主要为大家详细介绍了如何使用C#在.NET程序中实现对Excel单元格数字格式的设置,帮助实现更完善的Excel文件处理,感兴趣的小伙伴可以了解下

设置Excel单元格的数字格式是创建、修改和格式化Excel文档的关键步骤之一,它不仅确保了数据的正确表示,还能够增强数据的可读性和专业性。正确的数字格式可以帮助用户更直观地理解数值的意义,减少误解,并且对于自动化报告生成、财务计算等应用场景来说,精确的格式控制也是保证数据准确性和一致性的重要保障。在.NET平台上,我们可以使用C#轻松完成Excel单元格的数字格式设置,实现自动化处理。

本文将介绍如何使用C#在.NET程序中实现对Excel单元格数字格式的设置,帮助实现更完善的Excel文件处理。

本文所使用的方法需要用到免费的Free Spire.XLS for .NET,NuGet:PM> Install-Package FreeSpire.XLS

用C#设置Excel单元格的数字格式

Excel单元格数字格式的设置可以通过数字格式代码来实现。使用CellRange.Value或CellRange.NumberValue属性向单元格添加值之后,我们可以再使用CellRange.NumberFormat属性通过格式代码设置数值的显示格式。格式代码请参考:Excel单元格数字格式代码。

以下是操作步骤示例:

  • 导入所需模块。
  • 创建Workbook对象。
  • 使用Workbook.Worksheets[]属性获取指定获取工作表。
  • 使用Worksheet.Range[]可获取指定单元格,然后可以使用CellRange.Value或CellRange.NumberValue属性向指定单元格添加值。
  • 使用CellRange.NumberFormat属性通过格式代码设置数值的显示格式。
  • 使用Workbook.SaveToFile()方法保存工作簿,并释放资源。

代码示例

using System.Drawing;
using Spire.Xls;

class Program
{
    static void Main(string[] args)
    {
        // 创建一个新的工作簿实例
        Workbook workbook = new Workbook();

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

        // 添加标题
        sheet.Range["B1"].Text = "数字格式";
        sheet.Range["B1"].Style.Font.IsBold = true;
        sheet.Range["B1"].Style.Font.FontName = "HarmonyOS Sans SC";
        sheet.Range["B1:C1"].Merge();
        sheet.Range["B1:C1"].Style.HorizontalAlignment = HorizontalAlignType.Center;

        // 添加数字格式示例及对应的值
        AddNumberFormatExample(sheet, "B3", "C3", "0", "1234.5678"); // 格式为整数
        AddNumberFormatExample(sheet, "B4", "C4", "0.00", "1234.5678"); // 格式为保留两位小数
        AddNumberFormatExample(sheet, "B5", "C5", "#,##0.00", "1234.5678"); // 格式为带千位分隔符且保留两位小数
        AddNumberFormatExample(sheet, "B6", "C6", "$#,##0.00", "1234.5678"); // 格式为货币格式

        // 添加负数格式示例
        AddNumberFormatExample(sheet, "B7", "C7", "0;[Red]-0", "-1234.5678"); // 格式为负数用红色显示
        AddNumberFormatExample(sheet, "B8", "C8", "0.00;[Red]-0.00", "-1234.5678"); // 格式为保留两位小数,负数用红色显示

        // 添加科学计数法和百分比格式示例
        AddNumberFormatExample(sheet, "B9", "C9", "0.00E+00", "1234.5678"); // 格式为科学计数法
        AddNumberFormatExample(sheet, "B10", "C10", "0.00%", "0.5678"); // 格式为百分比

        // 添加日期和时间格式示例
        AddNumberFormatExample(sheet, "B11", "C11", "yyyy-MM-dd", "44930.0"); // Excel 日期值对应 2023-01-01
        AddNumberFormatExample(sheet, "B12", "C12", "HH:mm:ss", "0.75"); // Excel 时间值对应 18:00:00

        // 添加文本格式示例
        AddNumberFormatExample(sheet, "B13", "C13", "@", "文本示例"); // 格式为文本

        // 设置格式
        sheet.Range["B3:B13"].Style.Color = Color.Gray;
        sheet.Range["C3:C13"].Style.Color = Color.LightGray;
        sheet.Columns[1].ColumnWidth = 24;
        sheet.Columns[2].ColumnWidth = 24;

        // 将工作簿保存到文件
        workbook.SaveToFile("output/设置Excel单元格数字格式.xlsx", ExcelVersion.Version2016);
    }

    private static void AddNumberFormatExample(Worksheet sheet, string textCell, string valueCell, string format, string value)
    {
        sheet.Range[textCell].Text = format; // 显示数字格式代码
        sheet.Range[valueCell].Value = value; // 添加值
        // sheet.Range[valueCell].NumberValue = Double // 或添加数值
        sheet.Range[valueCell].NumberFormat = format; // 应用数字格式
    }
}

结果

用C#添加指定格式的值到Excel单元格

我们还可以直接使用库中提供的CellRange类下的属性,直接向单元格或单元格范围添加指定类型的带格式的值。以下是属性及对应添加的值:

属性
Text文本(string)
NumberValue数值(Double)
BooleanValue布尔值(Boolean)
DateTimeValue日期和时间(DateTime)
HtmlStringHTML格式字符代码(string)

以下是操作步骤示例:    

  • 导入所需模块。
  • 创建Workbook对象。
  • 使用Workbook.Worksheets[]属性获取指定获取工作表。
  • 使用Worksheet.Range[]可获取指定单元格。
  • 使用CellRange类下的属性向指定单元格添加指定类型的值。
  • 根据需要设置格式。
  • 使用Workbook.SaveToFile()方法保存工作簿,并释放资源。

代码示例

using System;
using Spire.Xls;

class Program
{
    static void Main(string[] args)
    {
        // 创建一个新的工作簿实例
        Workbook workbook = new Workbook();

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

        // 添加文本值
        sheet.Range["C3"].Text = "示例文本";
        // 添加数值
        sheet.Range["C4"].NumberValue = 1234.5678;
        // 添加布尔值
        sheet.Range["C5"].BooleanValue = true;
        // 添加日期时间值
        sheet.Range["C6"].DateTimeValue = new DateTime(2024, 12, 12);
        // 添加 HTML 字符串
        sheet.Range["C7"].HtmlString = "<b>加粗文本</b>";

        // 格式化单元格
        sheet.Range["C3:C7"].Style.HorizontalAlignment = HorizontalAlignType.Center;
        sheet.Range["C3:C7"].Style.VerticalAlignment = VerticalAlignType.Center;
        sheet.Range["C3:C7"].Style.Font.Size = 14;

        // 自动调整列宽
        for (int i = 3; i <= 7; i++)
        {
            sheet.AutoFitColumn(i - 1); // 注意:C#中列索引从0开始
        }

        // 保存工作簿
        workbook.SaveToFile("output/添加带数字格式的值到Excel.xlsx", ExcelVersion.Version2016);

        // 清理资源
        workbook.Dispose();
    }
}

结果

到此这篇关于.NET使用C#设置Excel单元格数值格式的文章就介绍到这了,更多相关C#设置Excel单元格数值格式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#实现合并多张图片为GIF动态图

    C#实现合并多张图片为GIF动态图

    这篇文章主要为大家详细介绍了C#如何将把一张又一张的图片去拼合成一张GIF动态图片,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2022-12-12
  • C# WPF 内置解码器实现 GIF 动图控件的方法

    C# WPF 内置解码器实现 GIF 动图控件的方法

    本文给大家介绍C# WPF内置解码器实现GIF动图控件的方法,文章对比了WPF与WinForm显示动态GIF的差异,列举了MediaElement、嵌入PictureBox、WpfAnimatedGif等解决方案,感兴趣的朋友跟随小编一起看看吧
    2025-08-08
  • C#从XmlDocument提取完整字符串的方法

    C#从XmlDocument提取完整字符串的方法

    文章介绍了两种生成格式化XML字符串的方法,方法一使用`XmlDocument`的`OuterXml`属性,但输出的XML字符串不带格式,可读性差,方法二利用`XmlWriterSettings`控制格式,并通过`MemoryStream`作为输出流,可以自定义编码,如UTF-8,感兴趣的朋友跟随小编一起看看吧
    2025-02-02
  • 总结的5个C#字符串操作方法分享

    总结的5个C#字符串操作方法分享

    这篇文章主要介绍了总结的5个C#字符串操作方法分享,本文讲解了把字符串按照分隔符转换成 List、把字符串转 按照, 分割 换为数据、得到数组列表以逗号分隔的字符串、得到字符串长度等方法,需要的朋友可以参考下
    2015-05-05
  • C#借助Spire.XLS for .NET实现在Excel中添加文档属性

    C#借助Spire.XLS for .NET实现在Excel中添加文档属性

    在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.XLS for .NET,实现对Excel文档属性的程序化添加和修改,感兴趣的小伙伴可以了解下
    2025-12-12
  • Unity实现识别图像中主体及其位置

    Unity实现识别图像中主体及其位置

    EasyDL基于飞桨开源深度学习平台,面向企业AI应用开发者提供零门槛AI开发平台,实现零算法基础定制高精度AI模型。本文将利用Unity和EasyDL实现识别图像中主体及其位置,感兴趣的可以了解一下
    2022-02-02
  • unity自定义弹出框功能

    unity自定义弹出框功能

    这篇文章主要为大家详细介绍了unity自定义弹出框功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • 使用C#开发Socket通讯的方法

    使用C#开发Socket通讯的方法

    使用C#开发Socket通讯的方法...
    2007-04-04
  • C#爬取动态网页上信息得流程步骤

    C#爬取动态网页上信息得流程步骤

    动态内容网站使用 JavaScript 脚本动态检索和渲染数据,爬取信息时需要模拟浏览器行为,否则获取到的源码基本是空的,这篇文章主要给大家详细介绍了C#爬取动态网页上信息得流程步骤,需要的朋友可以参考下
    2024-10-10
  • C# WebApi CORS跨域问题解决方案

    C# WebApi CORS跨域问题解决方案

    本篇文章主要介绍了C# WebApi CORS跨域问题解决方案,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07

最新评论