記錄一下這個歷史性的時刻!糾結了好久的問題終于解決了。
首先要感謝一下這個帖子:https://bbs.csdn.net/topics/392568534
這個博主針對問題:openpyxl用data_only=True后,讀取公式的值后save后,發現文件中公式都沒了,請問有解決辦法嗎?提出,用win32打開再保存:
def just_open(filename):
xlApp = Dispatch("Excel.Application")
xlApp.Visible = False
xlBook = xlApp.Workbooks.Open(filename)
xlBook.Save()
xlBook.Close()
好了,說下我糾結的問題:
我想調用一個充滿N多個公式的excel,實現:打開這個excel,修改某個參數值,希望讀取到隨著這個參數值改變后的單元格的數值。
實現方法:
import openpyxl
from win32com.client import Dispatch
def just_open(filename):
xlApp = Dispatch("Excel.Application")
xlApp.Visible = False
xlBook = xlApp.Workbooks.Open(filename)
xlBook.Save()
xlBook.Close()
wbDataOnly2 = openpyxl.load_workbook('C3.xlsx', data_only=False)#打開excel,為False表示不顯示公式
#sheet2 = wbDataOnly2.active
sheet2 = wbDataOnly2.get_sheet_by_name(u'參數表')
sheet2['D5'].value = 2000
wbDataOnly2.save('C3_1.xlsx')
just_open('C3_1.xlsx')
wbDataOnly3 = openpyxl.load_workbook('C3_1.xlsx', data_only=True)#再次打開新保存的excel,為True表示顯示公式計算結果
sheet3 = wbDataOnly3.get_sheet_by_name(u'參數表')
print sheet3['D65'].value
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
