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中的公式和函数而保留其计算结果。

相关推荐
weixin_580614003 小时前
如何提取SQL日期中的年份_使用YEAR或EXTRACT函数
jvm·数据库·python
2301_813599553 小时前
SQL生产环境规范_数据库使用最佳实践
jvm·数据库·python
李可以量化3 小时前
QMT 量化实战:用 Python 实现线性回归通道,精准识别趋势中的支撑与压力(下)
python·qmt·量化 qmt ptrade
a9511416423 小时前
Go 中通过 channel 传递切片时的数据竞争与深拷贝解决方案
jvm·数据库·python
Dxy12393102163 小时前
Python 使用正则表达式将多个空格替换为一个空格
开发语言·python·正则表达式
qq_189807033 小时前
如何修改RAC数据库名_NID工具在集群环境下的改名步骤
jvm·数据库·python
zhangchaoxies4 小时前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
Luca_kill4 小时前
MCP数据采集革命:从传统爬虫到智能代理的技术进化
爬虫·python·ai·数据采集·mcp·webscraping·集蜂云
zhangchaoxies4 小时前
CSS如何实现响应式弹性网格布局_配合media query修改flex-wrap属性
jvm·数据库·python
故事和你915 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论