記錄一下這個(gè)歷史性的時(shí)刻!糾結(jié)了好久的問(wèn)題終于解決了。
首先要感謝一下這個(gè)帖子:https://bbs.csdn.net/topics/392568534
這個(gè)博主針對(duì)問(wèn)題:openpyxl用data_only=True后,讀取公式的值后save后,發(fā)現(xiàn)文件中公式都沒(méi)了,請(qǐng)問(wèn)有解決辦法嗎?提出,用win32打開再保存:
def just_open(filename):
xlApp = Dispatch("Excel.Application")
xlApp.Visible = False
xlBook = xlApp.Workbooks.Open(filename)
xlBook.Save()
xlBook.Close()
好了,說(shuō)下我糾結(jié)的問(wèn)題:
我想調(diào)用一個(gè)充滿N多個(gè)公式的excel,實(shí)現(xiàn):打開這個(gè)excel,修改某個(gè)參數(shù)值,希望讀取到隨著這個(gè)參數(shù)值改變后的單元格的數(shù)值。
實(shí)現(xiàn)方法:
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'參數(shù)表')
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表示顯示公式計(jì)算結(jié)果
sheet3 = wbDataOnly3.get_sheet_by_name(u'參數(shù)表')
print sheet3['D65'].value
?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

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