Python 如何读取有公式cell的结果内容
admin
2023-01-20 10:20:50
0
    操作Excel通常是用如下三个扩展体:

import xlrd
import xlwt
import openpyxl

    xlrd(读) 和 xlwt(写)是一对。openpyxl独立,即可读也可写。
    正常读都没有问题,只是读有公式的cell时,会出现如题症状。对此,xlrd似乎没答案,而openpyxl开出的方子如下:

wb1 = openpyxl.load_workbook(xlsxFileWithFullPath, data_only=True)

就是加上 “data_only=True” 这个参数。
xlsxFileWithFullPath ---要操作的文件。
加上以后你会发现,还是依然如故,或者是时可时否!

如把文件打开,再保存一遍,执行程序,第一遍可以,第二遍就不行了!

其实, 关于 data_only=True 这个参数有个重要说明:

# data_only (bool) – controls whether cells with formula have either the formula (default) or the value stored the last time Excel read the sheet

这就解释了上述时可时否的问题。

这样解决问题的办法就有了:用程序来完成那个保存文件的任务即可!

(1)。。。
def ReadLine(self, tip1, tip2, movingRC, fixedRC, RorC, totalCells, sheetName, xlsxFileWithFullPath):

[!!]just open and save the file once! why? see bellow!

xlsxDealer.`JustOpenAndSaveTheFile`(xlsxFileWithFullPath)

(2)。。。

def JustOpenAndSaveTheFile(self, file_name):
from win32com.client import Dispatch
xlApp = Dispatch("Excel.Application")
xlApp.Visible = False
xlBook = xlApp.Workbooks.Open(file_name)
xlBook.Save()
xlBook.Close()

问题是解决了,速度就是有点慢!

相关内容

热门资讯

【今日要闻】“八闽福建麻将.真... 家人们!今天小编来为大家解答八闽福建麻将透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
重磅消息“推大石28杠.到底是... 家人们!今天小编来为大家解答推大石28杠透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里...
【第一资讯】“科乐填大坑.辅助... 您好:科乐填大坑这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游...
玩家最新攻略“丁丁麻将.辅助器... 有 亲,根据资深记者爆料丁丁麻将是可以开挂的,确实有挂(咨询软件无需打开...
【第一资讯】“乐享牛牛.是不是... 有 亲,根据资深记者爆料乐享牛牛是可以开挂的,确实有挂(咨询软件无需打开...
终于懂了“十三十三水经典比鸡.... 您好:十三十三水经典比鸡这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家...
【第一消息】“湘乐.究竟有挂吗... 【第一消息】“湘乐.究竟有挂吗?”其实是有挂您好,湘乐这个游戏其实有挂的,确实是有挂的,需要了解加客...
今日重大消息“越乡游新昌麻将.... 有 亲,根据资深记者爆料越乡游新昌麻将是可以开挂的,确实有挂(咨询软件无...
【今日要闻】“麻友圈2.是不是... 有 亲,根据资深记者爆料麻友圈2是可以开挂的,确实有挂(咨询软件无需打开...
今日重大通报“大富豪app.有... 网上科普关于“大富豪app有没有挂”话题很是火热,小编也是针对大富豪app作*弊开挂的方法以及开挂对...