我正在使用gtk的python。 我想下载一个文件,当发生这种情况时,我在窗口上绘制了一个GIF动画。 但每次下载开始时,gif都会冻结。我认为gobject调用应该解决这个问题,但似乎不喜欢。
电话是:
在gui班
...
gobject.timeout_add(3000, self.load)
gtk.main()
和加载功能:
def load(self):
ul = urllib2.open('http://xxxx/')
data = ul.read()
while gtk.events_pending():
gtk.main_iteration()
return True
每次调用加载gui堆栈。有什么方法可以做得更好吗?
原始代码:
self.opener = urllib2.build_opener()
self.opener.addheaders.append(('Cookie', self.cookie))
self.state = self.opener.open('http://'+gd_adress+'/state.cst?Lang=en')
self.state_data = self.state.read()
答案 0 :(得分:3)
您需要使用与GObject主循环集成的异步调用。
最简单的方法是使用GIO:
import gio
f = gio.File(uri='http://xxxx/')
def on_ready(gdaemonfile, result):
data, length, tag = f.load_contents_finish(result)
f.load_contents_async(on_ready)
Jono Bacon写了一篇很棒的文章:http://www.jonobacon.org/2010/03/15/download-files-async-with-gio-and-python/
不幸的是,就我所知,GIO不支持设置HTTP cookie。在这种情况下,最好的选择可能是使用线程并使用GLib.idle_add
将数据返回到主循环,如Webkit threads with PyGObject on Gtk3中所示:
import threading
import glib
glib.threads_init()
def load_data():
opener = urllib2.build_opener()
opener.addheaders.append(('Cookie', cookie))
state = opener.open('http://'+gd_adress+'/state.cst?Lang=en')
state_data = state.read()
glib.idle_add(on_read_data, state_data)
thread = threading.Thread(target=load_data)
thread.start()
这个想法是,它将阻塞调用封装在一个线程中,该线程在准备就绪时将数据返回给主线程,因此代码的其余部分可以忽略正在使用线程的事实。