51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 895|回复: 1
打印 上一主题 下一主题

[转贴] Python使用pywebview开发桌面应用

[复制链接]
  • TA的每日心情
    擦汗
    前天 08:59
  • 签到天数: 1021 天

    连续签到: 2 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2022-6-28 11:34:44 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    前言
      之前用过Eel做的桌面应用觉得已经够屌了,不过由于Eel是调用Chrome,时常出现各种小问题,比如窗口大小设置后有时候不管用,鼠标右键菜单无法禁用(一眼就能看出来是个web).而且尝试了用pyinstaller打包后文件好大,昨天晚上闲逛又发现了个比Eel更好的解决方案pywebview,更轻量,可自定义的设置更多。
      由于pywebview是直接调用系统自身的浏览器(Win10调用Edge,Win7调用IE),因此很适合打包发布。
      官网:pywebview.flowrl.com/
      最简单应用上手
      先装上轮子
    1.   pip install pywebview
    复制代码
    实现一个内嵌百度首页的winform程序,固定窗口大小,禁止选择文字。

    1.  """
    2.   main.py
    3.   """
    4.   import webview
    5.   window = webview.create_window(
    6.       title='百度一下,全是广告',
    7.       url='http://www.baidu.com',
    8.       width=850,
    9.       height=600,
    10.       resizable=False,    # 固定窗口大小
    11.       text_select=False,   # 禁止选择文字内容
    12.       confirm_close=True   # 关闭时提示
    13.   )
    14.   webview.start()
    复制代码

    无论是启动速度,还是显示效果都要比Eel好很多。
      退出提示的窗口默认显示的是英文,可以本地化一下,定义个字典传给webview.start()当启动参数就行了。
    1.  chinese = {
    2.       'global.quitConfirmation': u'确定关闭?',
    3.   }
    4.   webview.start(localization=chinese)
    复制代码

    高阶应用
      在HTML前端界面中调用Python中的函数
      Http是由Flask提供的,直接将Flask实例化对象app传给url参数就行了。
    1. import webview
    2.   from flask import Flask, render_template
    3.   # 实例化flask对象
    4.   app = Flask(__name__)
    5.   # 定义路由渲染模板
    6.   @app.route('/')
    7.   def index():
    8.       return render_template('/index.html')
    9.   # 配置pywebview关闭提示的中文翻译
    10.   chinese = {
    11.       'global.quitConfirmation': u'确定关闭?',
    12.   }
    13.   # 传给前端的api对象, 定义了一个可以通过js调用退出当前应用的函数
    14.   class Api:
    15.       def __init__(self) -> None:
    16.           self._window = None
    17.       def set_window(self, window):
    18.           self._window = window
    19.       def quit(self):
    20.           self._window.destroy()
    21.   if __name__ == '__main__':
    22.   # 实例化Api类
    23.       api = Api()
    24.       window = webview.create_window(
    25.           title='我是一个标题',
    26.           url=app,
    27.           fullscreen=True,# 以全屏模式启动
    28.           # width=760,# 自定义窗口大小
    29.           # height=390,
    30.           # resizable=False,  # 固定窗口大小
    31.           text_select=False,  # 禁止选择文字内容
    32.           confirm_close=True,  # 关闭时提示
    33.           js_api=api  # 将上面实例化后的Api对象传给前端js调用
    34.       )
    35.       # --划重点--务必记得需要将上面创建的window对象再通过函数传给实例化后的api对象
    36.       api.set_window(window)
    37.       # 启动程序
    38.       webview.start(localization=chinese)
    复制代码
    前端写一个id为exit的button, jquery给它绑定个点击的事件来调用api函数方法, 注意这里的pywebview.api是在pywebview的应用启动后自动注入到当前浏览器窗口中的全局对象, python中写的函数就绑定在它下面。
    1.  $("#exit").click(function () {
    2.   pywebview.api.quit();
    3.   })
    复制代码
    打包成单个EXE文件
      之前用pyinstaller手工打包太麻烦了, 发现个图形化的配置pyinstaller进行打包的工具: auto-py-to-exe, 用pip装一下, 然后就可以直接启动了。
    1.  pip install auto-py-to-exe
    2.   # 启动工具
    3.   auto-py-to-exe
    复制代码
    这工具居然是用eel写的, 哈哈...
      推荐使用单目录方式进行打包, 单文件的话可能会对程序代码中涉及到路径引用的地方出现问题, 坑有点大, 不推荐使用。
      需要注意的是要在附加文件一块设置中将flask涉及到的模板, 静态文件, 还有其他诸如sqlite数据库文件都添加进去。

    判断页面中pywebview.api对象是否加载成功
      今天又写了个小应用,调用的本地的html文件,想要在页面打开的时候直接调用pywebview.api中关联的python函数,但是由于页面中直接用js访问pywebview.api对象的话会报错找不到对象,又翻了下官方文档,发现需要给window对象添加个事件监听pywebviewready,示例代码:
    1. <script>
    2.     window.addEventListener('pywebviewready', function () {
    3.       pywebview.api.hl('aaa').then(function (res) {
    4.         document.querySelector('#hl').textContent = res.rate
    5.       })
    6.     })
    7.   </script>
    复制代码








    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2022-6-25 16:45
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    2#
    发表于 2022-6-28 12:25:09 | 只看该作者
    每天学到一个新知识
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-9-21 12:47 , Processed in 0.068058 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表