我看到的唯一方法就是运行一个网络引擎。。。在
使用QtWebKitQWebFrame可以使用setHtml,^{}将返回由WebKit改编的源代码。。。在
显然这是一个很大的依赖关系,但是只要安装PySide就可以得到所需的一切。在
所以这比我预期的要脏得多,至少是将Qt与其他代码隔离开来所需要的部分。使用setHtml似乎不允许您立即使用toHtml;某些异步加载必须发生。。。在
寻找一些更简单的WebKit绑定可能会更有意义。在
因此,load_source都从URL下载数据,并在WebKit修改后返回HTML。它用异步事件包装Qt的事件循环,是一个阻塞函数。在
如果您想单独下载,这里的setUrl可以替换为setHtml。在from PySide.QtCore import QObject, QUrl, Slot
from PySide.QtGui import QApplication
from PySide.QtWebKit import QWebPage, QWebSettings
qapp = QApplication([])
def load_source(url):
page = QWebPage()
page.settings().setAttribute(QWebSettings.AutoLoadImages, False)
page.mainFrame().setUrl(QUrl(url))
class State(QObject):
src = None
finished = False
@Slot()
def loaded(self, success=True):
self.finished = True
if self.src is None:
self.src = page.mainFrame().toHtml()
state = State()
# Optional; reacts to DOM ready, which happens before a full load
def js():
page.mainFrame().addToJavaScriptWindowObject('qstate$', state)
page.mainFrame().evaluateJavaScript('''
document.addEventListener('DOMContentLoaded', qstate$.loaded);
''')
page.mainFrame().javaScriptWindowObjectCleared.connect(js)
page.mainFrame().loadFinished.connect(state.loaded)
while not state.finished:
qapp.processEvents()
return state.src
使用链接问题中的示例进行演示。现在它真的起作用了。。。在
^{pr2}$