QTimer timer;
创新互联公司-专业网站定制、快速模板网站建设、高性价比凤阳网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式凤阳网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖凤阳地区。费用合理售后完善,十余年实体公司更值得信赖。
timer.setInterval(1000);
timer.start();
connect(timer,SIGNAL(timeOut()),this,SLOT(myTimerout()));
void thisObject::myTimerOut()
{
ui-textBrowser-append(QString("hello === %1").arg(i));
}
用openpyxl读取excel的load_workbook有个data_only参数。
例如:
yb_wb = load_workbook(u"D:\Desktop\xxx.xlsx", data_only=True)顾名思义,True时,只读data,忽略公式。
但是有个情景是——得先保留公式,根据旧公式写入新公式。然后再读取值进行操作。也就是说先data_only = False,然后再data_only = True。
这样会导致读取值操作的时候,公式全部没有了。对,全部为空。就是这么奇怪。
wb = openpyxl.load_workbook(‘abc.xlsx’, data_only=True)
当’abc.xlsx’被生成并在Excel程序中打开并保存之后(这个过程Excel会把公式结果计算出来),该文件附带有两套值,一套是公式全都没有计算的(data_only=False(默认)),一套是公式计算了结果的(data_only=True)。(如果没有被Excel打开并保存,则只有一套值(data_only=False的那套,公式没有计算结果的)。
此时,以data_only=True或默认data_only=False打开会得到两种不同的结果,各自独立,即data_only=True状态下打开的,会发现公式结果为None(空值)或者一个计算好的常数,而不会看到它原本的公式是如何。而data_only=False则只会显示公式而已。因此,data_only=True状态下打开,如果最后用save()函数保存了,则原xlsx文件中,公式会被替换为常数结果或空值。而data_only=False状态下打开,最后用save()函数保存了的话,原xlsx文件也会只剩下data_only=False的那套值(即公式),另一套(data_only=True)的值会丢失,如想重新获得两套值,则仍旧需要用Excel程序打开该文件并保存。
解决方法:
可以定义一个刷新函数重新打开一次并保存。
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()
print('自动更新结束')
filename = r"D:\Desktop\xxx.xlsx"
just_open(filename)
先调用win32com打开一次,就OK,原公式就会变成值,后面就可以愉快的操作了。
一个建议的编程思想:
通过一个可变变量来传递任务完成的进度,例如可变变量命名为p,(p位于0到1之间,表示百分比。)
主程序显示一个progressbar,其值为p。
DoJob()在运行过程中会更改p的值。
则此更改在mainloop()的作用下将实时显示到progressbar上。
from tkinter import *
import time
def updatetimer():
timer=time.strftime("%H:%M:%S")
timelabel.configure(text=timer)
timelabel.after(1000,updatetimer)
root=Tk()
timelabel=Label(root)
timelabel.pack()
timelabel.after(1000,updatetimer)
root.mainloop()
是在IDLE中? 清空当前屏幕就可以了 cls , 或者你就重新赋值,默认会自动覆盖的