0

我开发了一个基于 Web 的工具,目前正在尝试使其可通过 python 启动。我认为使用 CEFpython 可能是这样做的方法。我按照教程here并编写了以下代码:

from cefpython3 import cefpython as cef
import base64
import platform
import sys
import threading
import os

HTML_code = """
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
        <link href="static/css/main.css" rel="stylesheet" />
    </head>
    <body>
        <div id="UI">
        </div>
        <div id="container"></div>

        <script src="static/main.js"></script>
        <script type="text/javascript">
            function defineData(datainput){

                console.log("start")
                data = datainput;
                var loc = window.location.pathname;
                var dir = loc.substring(0, loc.lastIndexOf('/'));
                console.log(loc);
                console.log(dir);
                Main();
            }
        </script>

    </body>
</html>

"""
def html_to_data_uri(html):
    html = html.encode("utf-8", "replace")
    b64 = base64.b64encode(html).decode("utf-8", "replace")
    ret = "data:text/html;base64,{data}".format(data=b64)
    return ret


def main(config):

    sys.excepthook = cef.ExceptHook  # To shutdown all CEF processes on error
    settings = {}
    cef.Initialize(settings=settings)

    browser = cef.CreateBrowserSync(url=html_to_data_uri(HTML_code),window_title="Test")

    browser.SetClientHandler(LoadHandler(config))
    cef.MessageLoop()
    cef.Shutdown()
    return 

class LoadHandler(object):

    def __init__(self, config):
        self.config = config
    def OnLoadingStateChange(self, browser, is_loading, **_):
        """Called when the loading state has changed."""
        if not is_loading:
            # Loading is complete. DOM is ready.
            browser.ExecuteFunction("defineData", self.config)

不幸的是,与本教程不同的是,我的工具必须加载定义主要功能的本地 .js 文件(),如果我以这种方式编写 html 文件,我的工作目录实际上并不是我调用脚本的目录,而是一些奇怪的地方

这些行的输出是:

var loc = window.location.pathname;
var dir = loc.substring(0, loc.lastIndexOf('/'));
console.log(loc);
console.log(dir);

输出:

text/html;base64,CjwhRE9DVFlQRSBodG1sPgo8aHRtbCBsYW5nPSJlbiI+Cgk8aGVhZD4KCQk8bWV0YSBjaGFyc2V0PSJ1dGYtOCI+CgkJPG1ldGEgbmFtZT0idmlld3BvcnQiIGNvbnRlbnQ9IndpZHRoPWRldmljZS13aWR0aCwgdXNlci1zY2FsYWJsZT1ubywgbWluaW11bS1zY2FsZT0xLjAsIG1heGltdW0tc2NhbGU9MS4wIj4KCQk8bGluayBocmVmPSJzdGF0aWMvY3NzL21haW4uY3NzIiByZWw9InN0eWxlc2hlZXQiIC8+CgkJPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCQkJKiB7CgkJCQkuYm9yZGV....

text

你能帮我找到用正确路径在python中硬编码html代码的正确方法吗?也许我需要以某种方式设置路径?

PS:我确实尝试将 html 代码包含在一个单独的 .html 文件中,它可以在 Windows 机器上运行,但似乎 MacOS 不喜欢它。由于本教程确实适用于 MAC,我正在尝试将 html 部分硬编码到 python 脚本中,并希望它适用于 Windows 和 Mac

4

1 回答 1

0

嗯,HTML 文档已经通过 转换为数据 URI的主体html_to_data_uri,因此文档的 U[niversal]R[esource]L[ocator] ( window.location) 不是服务器上的位置,而是数据 URI 本身(你提到的“奇怪的地方”)。

请记住,URL 是 URI 的子集,并且您将 URI 作为 URL 传递给 CEF:

    browser = cef.CreateBrowserSync(url=html_to_data_uri(HTML_code),window_title="Test")

因此,只要您使用数据 URI/URL,我认为这window.location不会有帮助。相反,您可以将 HTML 代码提取到一个单独的.html文件中,并将该行更改为:

    browser = cef.CreateBrowserSync(url="/path/to/that_html_file.html", window_title="Test")
于 2020-05-23T05:08:53.807 回答