Openpyxl 1.8.5:使用 openpyxl 读取单元格中输入的公式的结果

2025-03-21 09:07:00
admin
原创
40
摘要:问题描述:我正在其中一个 Excel 表中打印一些公式:wsOld.cell(row = 1, column = 1).value = "=B3=B4" 但我不能使用它的结果来实现其他逻辑,例如:if((wsOld.cell(row=1, column=1).value)='true'):...

问题描述:

我正在其中一个 Excel 表中打印一些公式:

wsOld.cell(row = 1, column = 1).value = "=B3=B4"

但我不能使用它的结果来实现其他逻辑,例如:

if((wsOld.cell(row=1, column=1).value)='true'):
    # copy the 1st row to another sheet

即使我尝试在命令行中打印结果,我最终也会打印公式:

>>> print(wsOld.cell(row=1, column=1))
>>> =B3=B4

如何才能获取单元格中公式的结果而不是公式本身?


解决方案 1:

openpyxl 支持公式或公式值。data_only打开工作簿时,您可以使用标志选择哪个。但是,openpyxl 不会也不会计算公式的结果。有些库(如 pycel)声称可以做到这一点。

解决方案 2:

xlwings、PyXll FlyingKoala、DataNitro 都使用Excel作为使用Python的接口。

如果您想使用 Python 库,可以尝试PyCel、xlcalculator、Formulas和Schedula。

我是 xlcalculator 的项目所有者。

xlcalculator 使用 openpyxl 读取 Excel 文件并添加将 Excel 公式转换为 Python 的功能。

使用 xlcalculator 与 Excel 文件的示例:

from xlcalculator import ModelCompiler
from xlcalculator import Model
from xlcalculator import Evaluator

filename = r'use_case_01.xlsm'
compiler = ModelCompiler()
new_model = compiler.read_and_parse_archive(filename)
evaluator = Evaluator(new_model)
val1 = evaluator.evaluate('First!A2')
print("value 'evaluated' for First!A2:", val1)

使用 xlcalculator 和 dict 的示例;

input_dict = {
    "B4": 0.95,
    "B2": 1000,
    "B19": 0.001,
    "B20": 4,
    # B21
    "B22": 1,
    "B23": 2,
    "B24": 3,
    "B25": "=B2*B4",
    "B26": 5,
    "B27": 6,
    "B28": "=B19*B20*B22",
    "C22": "=SUM(B22:B28)",
  }

from xlcalculator import ModelCompiler
from xlcalculator import Model
from xlcalculator import Evaluator

compiler = ModelCompiler()
my_model = compiler.read_and_parse_dict(input_dict)
evaluator = Evaluator(my_model)

for formula in my_model.formulae:
    print("Formula", formula, "evaluates to", evaluator.evaluate(formula))

# cells need a sheet and Sheet1 is default.
evaluator.set_cell_value("Sheet1!B22", 100)
print("Formula B28 now evaluates to", evaluator.evaluate("Sheet1!B28"))
print("Formula C22 now evaluates to", evaluator.evaluate("Sheet1!C22"))

解决方案 3:

我已经使用 openpyxl 和 pandas 的组合解决了这个问题:

import pandas as pd
import openpyxl
from openpyxl import Workbook , load_workbook


source_file = "Test.xlsx"
# write to file
wb = load_workbook (source_file)
ws = wb.active
ws.title = "hello world"
ws.append ([10,10])
wb.save(source_file)

# read from file
df = pd.read_excel(source_file)
sum_jan = df ["Jan"].sum() 
print (sum_jan)

解决方案 4:

Openpyxl 并不完全支持 excel 计算公式。它仅支持非常基本的公式。如果您想计算工作簿中的所有公式,则应使用xlwings库(仅在 MacOS 和 Windows 上受支持)。

相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   2482  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1533  
  PLM(产品生命周期管理)项目对于企业优化产品研发流程、提升产品质量以及增强市场竞争力具有至关重要的意义。然而,在项目推进过程中,范围蔓延是一个常见且棘手的问题,它可能导致项目进度延迟、成本超支以及质量下降等一系列不良后果。因此,有效避免PLM项目范围蔓延成为项目成功的关键因素之一。以下将详细阐述三大管控策略,助力企业...
plm系统   0  
  PLM(产品生命周期管理)项目管理在企业产品研发与管理过程中扮演着至关重要的角色。随着市场竞争的加剧和产品复杂度的提升,PLM项目面临着诸多风险。准确量化风险优先级并采取有效措施应对,是确保项目成功的关键。五维评估矩阵作为一种有效的风险评估工具,能帮助项目管理者全面、系统地评估风险,为决策提供有力支持。五维评估矩阵概述...
免费plm软件   0  
  引言PLM(产品生命周期管理)开发流程对于企业产品的全生命周期管控至关重要。它涵盖了从产品概念设计到退役的各个阶段,直接影响着产品质量、开发周期以及企业的市场竞争力。在当今快速发展的科技环境下,客户对产品质量的要求日益提高,市场竞争也愈发激烈,这就使得优化PLM开发流程成为企业的必然选择。缺陷管理工具和六西格玛方法作为...
plm产品全生命周期管理   0  
热门文章
项目管理软件有哪些?
曾咪二维码

扫码咨询,免费领取项目管理大礼包!

云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用