Python保留数据删除Excel单元格的函数和公式

在分析处理Excel表格时,我们可能需要使用各种公式或函数对表格数据进行计算,从而分析出更多的信息。但在展示、分享或再利用分析结果时,我们可能需要将含有公式的单元格转换为静态数值,从而简化数据、保护计算结果不被更改,以及提高数据的可移植性。利用Python我们可以轻松实现公式或函数的批量移除,并保证数据不被改变。本文将介绍如何使用Python代码批量移除Excel单元格中的公式并保留数值

本文所使用的方法需要用到Spire.XLS for Python,PyPI:pip install spire.xls

批量移除单元格公式和函数并保留数值

我们可以遍历工作表中的已使用的行和列,使用Worksheet.Range[]来获取单元格并判断其是否包含公式或函数,然后再将单元格的值直接设置为公式或函数的计算结果,从而实现移除公式和函数并保留结果数值。

以下是详细操作步骤:

  1. 导入所需模块。
  2. 创建Workbook对象,并使用Workbook.LoadFromFile()方法载入Excel文件。
  3. 遍历工作簿中的工作表,使用Workbook.Worksheets.get_Item()方法获取工作表。
  4. 遍历工作表中的行和列,使用Worksheet.Range[int: rowIndex, int: colIndex]属性获取指定单元格。
  5. 通过判断CellRange.HasFormula属性的值从而判断单元格是否包含函数或公式,如果包含:
    • 使用CellRange.FormulaValue属性获取函数或公式的计算结果。
    • 使用CellRange.Clear(ExcelClearOptions.ClearContent)方法清除单元格内容。
    • 使用CellRange.Value属性将单元格的值设置为前面获取的计算结果。
  6. 使用Workbook.SaveToFile()方法保存工作簿。
  7. 释放资源。

代码示例

python 复制代码
from spire.xls import *

# 创建一个Workbook对象
workbook = Workbook()

# 从文件加载Excel工作簿
workbook.LoadFromFile("Sample.xlsx")

# 遍历所有工作表
for sheetIndex in range(workbook.Worksheets.Count):
    # 获取一个工作表
    sheet = workbook.Worksheets.get_Item(sheetIndex)
    # 遍历所有单元格
    for rowIndex in range(sheet.Rows.Count):
        for colIndex in range(sheet.Columns.Count):
            # 获取一个单元格
            cell = sheet.Range[rowIndex + 1, colIndex + 1]
            # 检查单元格是否有公式
            if cell.HasFormula:
                # 获取公式的计算结果
                formulaValue = cell.FormulaValue
                # 清除单元格内容
                cell.Clear(ExcelClearOptions.ClearContent)
                # 将单元格值设置为公式的结果
                cell.Value = formulaValue

# 保存工作簿
workbook.SaveToFile("output/ClearFormula.xlsx", FileFormat.Version2016)
# 释放资源
workbook.Dispose()

结果文件

申请免费License

本文演示了如何使用Python删除Excel中的公式和函数而保留其计算结果。

相关推荐
数据智能老司机4 小时前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
数据智能老司机5 小时前
精通 Python 设计模式——并发与异步模式
python·设计模式·编程语言
数据智能老司机5 小时前
精通 Python 设计模式——测试模式
python·设计模式·架构
数据智能老司机5 小时前
精通 Python 设计模式——性能模式
python·设计模式·架构
c8i6 小时前
drf初步梳理
python·django
每日AI新事件6 小时前
python的异步函数
python
这里有鱼汤7 小时前
miniQMT下载历史行情数据太慢怎么办?一招提速10倍!
前端·python
databook16 小时前
Manim实现脉冲闪烁特效
后端·python·动效
程序设计实验室16 小时前
2025年了,在 Django 之外,Python Web 框架还能怎么选?
python
倔强青铜三18 小时前
苦练Python第46天:文件写入与上下文管理器
人工智能·python·面试