lxwings能否读取原Excel内的公式?

我的原Excel里自带公式,要实现插入数据,要先读取这个Excel文件,可是pandas转化为datafra的过程中,这些公式会失效。
请问,lxwings是否能够读取原Excel文件中的公式来实现插入数据呢?如果不行,是否还有别的办法?万分感谢!

当然可以

需要使用公式, 就得用原生的excel库,比如openpyxl,xlwt,xlrd,xlwings 这些,他们会按照excel的标准的处理数据,
而不是像pandas一样将数据转为DataFrame (已经不是excel的格式了)

举个例子,这里C1 是公式 ,结果是 A1和B1相加而来

img

用Python处理

import openpyxl

# 读取和修改公式本身
file = openpyxl.open(r"新建 Microsoft Excel 工作表.xlsx")
print(file.active["C1"].value)

# 读取公式计算结果
e = openpyxl.open(r"新建 Microsoft Excel 工作表.xlsx", data_only=True)
print(e.active["C1"].value)

执行结果

=A1+B1
3

支持xls版本

import xlwings as xw

book = xw.Book(r"新建 Microsoft Excel 工作表.xls")
sheet = book.sheets["Sheet1"]
print(sheet.range("C1").formula) # 公式
print(sheet.range("C1").value)   # 公式的计算结果