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

如何使用 Python 设置 Excel 单元格数字格式

、环境准备

1.1 库安装

通过 pip 安装免费版本:

pip install spire.xls.free

安装完成后,在 Python 脚本中导入相关模块即可使用:

from spire.xls import * from spire.xls.common import *

1.2 核心概念

Excel 的数字格式作用于数值型数据,仅改变显示外观,不改变单元格的实际存储值。设置格式涉及两个核心属性:

  • NumberValue:写入单元格的原始数值(必须为数值类型)
  • NumberFormat:格式代码字符串,定义数值的显示规则

注意:若通过Text属性写入数字字符串,数字格式将不会生效。必须使用NumberValue赋值,才能保证格式正确应用。

二、常用数字格式分类与代码

Excel 数字格式代码遵循四段式结构:正数格式;负数格式;零值格式;文本格式,各段用分号分隔。实际使用中可根据需求省略部分段落。以下分类介绍高频场景。

2.1 常规数值与小数位数

控制小数点后的保留位数,以及是否显示千分位分隔符。

格式代码原始值显示效果说明
01234.561235整数,四舍五入
0.001234.51234.50固定两位小数
#,##012345671,234,567千分位分隔,无小数
#,##0.001234.5671,234.57千分位 + 两位小数

代码示例:

sheet.Range["D2"].NumberValue = 1234567.89 sheet.Range["D2"].NumberFormat = "#,##0.00"

2.2 货币格式

在数值前添加货币符号,通常配合千分位与小数位使用。

格式代码显示效果
¥#,##0.00¥1,234.56
$#,##0.00$1,234.56
€ #,##0.00€ 1,234.56

代码示例:

sheet.Range["D4"].NumberValue = 9999.99 sheet.Range["D4"].NumberFormat = "¥#,##0.00"

2.3 百分比格式

将小数乘以 100 后以百分比形式展示。

格式代码原始值显示效果
0%0.12312%
0.00%0.1234512.35%

代码示例:

sheet.Range["D6"].NumberValue = 0.12345 sheet.Range["D6"].NumberFormat = "0.00%"

2.4 日期与时间格式

Excel 内部以序列值存储日期(1900-01-01 对应数值 1),通过格式代码转换为可读日期。

格式代码原始值显示效果
yyyy-mm-dd455662024-10-01
yyyy年m月d日455662024年10月1日
m/d/yyyy4556610/1/2024
hh:mm:ss0.62515:00:00
h:mm AM/PM0.6253:00 PM
yyyy-mm-dd hh:mm45566.6252024-10-01 15:00

代码示例:

sheet.Range["D8"].NumberValue = 45566 sheet.Range["D8"].NumberFormat = "yyyy-mm-dd" sheet.Range["D9"].NumberValue = 0.625 sheet.Range["D9"].NumberFormat = "hh:mm:ss"

2.5 科学计数法

适用于极大或极小数值的紧凑展示。

格式代码原始值显示效果
0.00E+0012345671.23E+06
0.00E-000.00001231.23E-05

2.6 分数格式

以分数形式显示小数。

格式代码原始值显示效果
# ?/?0.753/4
# ??/??0.3331/3

2.7 条件颜色格式

根据数值正负自动显示不同颜色,方括号内指定颜色名称。

格式代码原始值显示效果
[Green]#,##0;[Red]-#,##0正数绿色,负数红色
[Red]#,##0.00全部显示为红色

代码示例:

sheet.Range["D12"].NumberValue = -1234.56 sheet.Range["D12"].NumberFormat = "[Green]#,##0.00;[Red]-#,##0.00"

2.8 自定义文本前缀/后缀

在数值前后附加固定文本,同时保持数值可计算性。文本需用双引号包裹。

格式代码原始值显示效果
"合计:"#,##0" 元"5000合计:5,000 元
0" 件"120120 件

三、完整示例代码

以下示例在同一张工作表中集中演示多种数字格式效果:

from spire.xls import * from spire.xls.common import * # 创建工作簿 workbook = Workbook() sheet = workbook.Worksheets.get_Item(0) sheet.Name = "数字格式示例" # 设置列宽 sheet.SetColumnWidth(2, 22) sheet.SetColumnWidth(3, 15) sheet.SetColumnWidth(4, 20) # 表头 sheet.Range["B2"].Text = "格式说明" sheet.Range["C2"].Text = "原始值" sheet.Range["D2"].Text = "显示结果" header_style = sheet.Range["B2:D2"].Style header_style.Font.IsBold = True header_style.HorizontalAlignment = HorizontalAlignType.Center # 示例数据与格式 examples = [ ("两位小数", 1234.567, "0.00"), ("千分位分隔", 1234567.89, "#,##0.00"), ("人民币货币", 9999.99, "¥#,##0.00"), ("美元货币", 9999.99, "$#,##0.00"), ("百分比两位", 0.12345, "0.00%"), ("日期格式", 45566, "yyyy-mm-dd"), ("时间格式", 0.625, "hh:mm:ss"), ("科学计数法", 1234567, "0.00E+00"), ("正负分色", -1234.56, "[Green]#,##0.00;[Red]-#,##0.00"), ("文本前缀", 5000, '"合计:"#,##0" 元"'), ] # 逐行写入 for i, (desc, value, fmt) in enumerate(examples, start=3): sheet.Range[f"B{i}"].Text = desc sheet.Range[f"C{i}"].NumberValue = value sheet.Range[f"C{i}"].NumberFormat = "General" sheet.Range[f"D{i}"].NumberValue = value sheet.Range[f"D{i}"].NumberFormat = fmt # 自动调整列宽 sheet.AllocatedRange.AutoFitColumns() # 保存文件 workbook.SaveToFile("number_format_demo.xlsx", ExcelVersion.Version2016) workbook.Dispose()

运行后将生成number_format_demo.xlsx文件,C 列为原始通用格式数值,D 列为应用格式后的显示效果。

四、格式代码语法规则

4.1 占位符含义

  • 0:数字占位符。若对应位无数字则显示 0,强制补位。
  • #:数字占位符。若对应位无数字则不显示,不补零。
  • ?:数字占位符。用于对齐分数的小数点。
  • .:小数点位置标记。
  • ,:千分位分隔符,或数值缩放(末尾逗号表示除以 1000)。

4.2 分段规则

格式代码最多分为四段,以分号分隔:

正数格式;负数格式;零值格式;文本格式
  • 只写一段:应用于所有数值
  • 写两段:第一段用于正数和零,第二段用于负数
  • 写三段:分别对应正、负、零
  • 写四段:增加文本格式规则

示例:#,##0.00;[Red]-#,##0.00;"-";@

含义:正数正常显示千分位两位小数;负数红色并带负号;零值显示为短横线;文本保持原样。

五、注意事项与常见问题

  1. 数值类型必须正确

    只有通过NumberValue写入的数值才能应用数字格式。若使用Text属性写入字符串形式的数字,格式代码不会生效。

  2. 格式代码区分区域设置

    部分格式符号(如千分位、日期分隔符)受系统区域设置影响。跨地区使用时建议采用标准格式代码。

  3. 日期序列值基准

    Excel 默认以 1900-01-01 为序列值 1。设置日期格式前需确认数值对应的日期是否正确。

  4. 免费版限制

    Free 版本存在工作表数量与行数限制,适用于小型文件处理场景。大规模数据处理需评估是否满足业务需求。

http://www.jsqmd.com/news/1094221/

相关文章:

  • 基于双阀值区间扰动观察法与带预测模型模糊PID控制法的光伏MPPT控制仿真模型研究(Simulink仿真实现)
  • NHS-PEG-Silane 综合功能特性解析 —— 低吸附、高偶联、强锚固三大核心优势
  • 中小律所案件管理系统怎么选?案件云、Alpha、iCourt 适合谁
  • TAS5711数字功放芯片全解析:从D类放大原理到2.1声道实战设计
  • 别再走弯路!2026实测靠谱的AI论文写作工具|实测必入避坑版
  • RAG 2026进化:从Naive到Agentic,混合检索与多模态实战拆解
  • 修改IntelliJ IDEA开发工具的缓存目录
  • 计算机毕业设计之基于SSM框架的智能车位管理系统的设计与实现
  • 如何用AI生成课程论文?2026年大学生高效完成课程论文的完整指南
  • zynq中linux应用的远程调试配置
  • 游戏开发测试白盒测试与黑盒测试
  • Canalyzer实战指南:从零上手汽车CAN报文解析与调试
  • SSRF漏洞深度解析:原理、攻击手法与立体化防御实战
  • 学术写作创新突破!2026全能型AI论文写作软件推荐指南
  • Navicat重置工具:3步实现Mac版无限试用的终极指南
  • 思源宋体TTF完全指南:如何免费获取专业级中文字体
  • 不用配置环境!OpenClaw 2.7.9 Win11 一键安装故障合集
  • Python 豆包AI实战:各种语言之间文字翻译
  • Agent 开发困境:构建已经免费,但验证还是地狱
  • 大模型学习笔记 · 第三篇 · 项目结构与训练是怎么跑起来的
  • C# 语言入门(一)基础介绍与程序规范
  • Web端自动化测试全解析:从工具选型到框架搭建实战
  • GPT-4稀疏激活真相:万亿参数如何仅用2%实现高效推理
  • 掌握开源工具:实现极域电子教室限制的高效解除方案
  • EPLAN Electric P8 2.9 批量编辑插件套装|设备改号+功能文本+页名+端子+连接点+中断点+文本|支持 Excel 导入导出
  • 海外红人营销Brief模板:产品信息、内容要求和复盘字段
  • 72%数字化转型折戟:别让伪AI低代码拖死业务
  • SSRF漏洞实战:从原理到防御的深度解析与渗透测试指南
  • 2026天猫代运营风向标:平台巨变下商家如何选对伙伴?汉聪领衔实力测评榜单出炉
  • OpCore-Simplify:3步完成黑苹果配置的终极简化方案