本文详解python中使用pywebview库时因脚本文件名与库名同名导致的循环导入错误,并提供正确配置方法与可运行示例。
在使用 pywebview 创建桌面端 Web 视图窗口时,一个常见却极易被忽视的问题是:脚本文件名与要导入的库名完全相同(如命名为 webview.py),这将触发 Python 的模块解析机制异常,最终导致 AttributeError: partially initialized module 'webview' has no attribute 'create_window' 错误。
该错误的本质是 循环导入(circular import):当执行 import webview 时,Python 在当前目录下找到同名的 webview.py 文件并优先加载它;而该文件内部又尝试 import webview,从而形成自我引用——模块尚未初始化完成就再次尝试导入自身,导致属性(如 create_window)不可用。
✅ 正确做法如下:
立即重命名你的脚本文件(例如改为 main.py、app.py 或 webviewer.py),确保其名称不与任何第三方包(尤其是 webview)冲突
;
确保已正确安装 pywebview(注意不是 webview):
pip install pywebview
使用标准调用方式(注意 URL 必须包含协议头):
import webview
if __name__ == '__main__':
# 注意:URL 必须以 http:// 或 https:// 开头
webview.create_window('Ridola Web View', 'https://www.google.com')
webview.start()⚠️ 其他注意事项:
webview.start(debug=True)
总结:90% 的 AttributeError: partially initialized module 'webview' 报错都源于脚本命名冲突。只需一次重命名 + 正确安装 + 协议完整 URL,即可快速构建稳定、轻量的 Windows 原生 Web 视图应用。