从X剪贴板获取HTML源或富文本

前端之家收集整理的这篇文章主要介绍了从X剪贴板获取HTML源或富文本前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如何从X剪贴板获取丰富的文本或HTML源代码?例如,如果您从Web浏览器复制一些文本并将其粘贴到kompozer中,则将其粘贴为HTML,并保留链接等。但是,对于相同的选择,xclip -o只是输出纯文本,以与elinks -dump类似的方式重新格式化。我想把HTML拉出来,进入一个文本编辑器(特别是vim)。

我问the same question on superuser.com,因为我希望有一个实用程序来做到这一点,但我没有得到任何翔实的回应。 X剪贴板API对我来说是一个神秘的野兽;任何关于黑客攻击的提示都是非常受欢迎的。我现在选择的语言是Python,但几乎任何事情都可以。

解决方法

在X11中,您必须与选择所有者通信,询问支持的格式,然后以特定格式请求数据。我认为最简单的方法是使用现有的窗口工具包。例如。与Python和GTK:
#!/usr/bin/python

import glib,gtk

def test_clipboard():
    clipboard = gtk.Clipboard()
    targets = clipboard.wait_for_targets()
    print "Targets available:",",".join(map(str,targets))
    for target in targets:
        print "Trying '%s'..." % str(target)
        contents = clipboard.wait_for_contents(target)
        if contents:
            print contents.data

def main():
    mainloop = glib.MainLoop()
    def cb():
        test_clipboard()
        mainloop.quit()
    glib.idle_add(cb)
    mainloop.run()

if __name__ == "__main__":
    main()

输出将如下所示:

$ ./clipboard.py 
Targets available: TIMESTAMP,TARGETS,MULTIPLE,text/html,text/_moz_htmlcontext,text/_moz_htmlinfo,UTF8_STRING,COMPOUND_TEXT,TEXT,STRING,text/x-moz-url-priv
...
Trying 'text/html'...
I asked <a href="http://superuser.com/questions/144185/getting-html-source-or-rich-text-from-the-x-clipboard">the same question on superuser.com</a>,because I was hoping there was a utility to do this,but I didn't get any informative responses.
Trying 'text/_moz_htmlcontext'...
<html><body class="question-page"><div class="container"><div id="content"><div id="mainbar"><div id="question"><table><tbody><tr><td class="postcell"><div><div class="post-text"><p></p></div></div></td></tr></tbody></table></div></div></div></div></body></html>
...
Trying 'STRING'...
I asked the same question on superuser.com,but I didn't get any informative responses.
Trying 'text/x-moz-url-priv'...
http://stackoverflow.com/questions/3261379/getting-html-source-or-rich-text-from-the-x-clipboard

猜你在找的HTML相关文章