将Streamlit应用打包成可执行的exe文件

当我们要运行Streamlit应用时,一般是通过命令行输入“streamlit run xxx.py”的方式。其实这样的操作已经很简单了,但是如果你还想再操作简单的话,那我们不妨试着将Streamlit应用变成一个可执行的exe文件,双击执行即可启动它。

  • 首先安装PyInstaller,推荐使用4.9版本,我们会用这个工具将Streamlit应用打包成exe文件,安装命令是“pip install pyinstaller”;
  • 对Streamlit的启动文件(假设是app.py)进行封装,新建一个新的文件(假设叫run_app.py)。这样后面,我们会通过执行run_app.py文件而不是原先的app.py文件来启动Streamlit应用。run_app.py的代码如下显示:
1 import streamlit
2 import streamlit.cli
3 from streamlit import bootstrap
4 
5 if __name__ == '__main__':
6     streamlit._is_running_with_streamlit = True
7     bootstrap.run('app.py', 'streamlit run', [], {})
  • 创建PyInstaller的Hook文件(假设叫hook_streamlit.py,放在hooks文件夹内),用于将streamlit包打包进可执行的exe文件中。hook_streamlit.py的代码如下显示:
1 from PyInstaller.utils.hooks import copy_metadata
2 datas = copy_metadata('streamlit')
  • 创建Streamlit应用的全局配置文件config.toml(放在.streamlit文件夹内),用于设置Streamlit应用的主题颜色、字体以及端口号等。config.toml的内容如下显示:
[theme]
primaryColor="#1576fe"
backgroundColor="#FFFFFF"
secondaryBackgroundColor="#F5F7FA"
textColor="#212121"
font="sans serif"
[server]
port=8552
headless=true
[browser]
gatherUsageStats = false
[global]
developmentMode = false
  • 通过命令“pyinstaller --onefile --additional-hooks-dir=./hooks run_app.py --clean”生成run_app.spec文件,后面会修改该文件并以此生成可执行的exe文件。我们对生成后的run_app.spec文件进行datas值的设置(初始时datas=[]),具体的内容如下显示:
 1 # -*- mode: python ; coding: utf-8 -*-
 2 
 3 
 4 block_cipher = None
 5 
 6 
 7 a = Analysis(
 8     ['run_app.py'],
 9     pathex=[],
10     binaries=[],
11     datas=[(
12             "{$YOURPYTHONENV}/Lib/site-packages/altair/vegalite/v4/schema/vega-lite-schema.json",
13             "./altair/vegalite/v4/schema/"
14         ),
15         (
16             "{$YOURPYTHONENV}/Lib/site-packages/streamlit/static",
17             "./streamlit/static"
18         )
19     ],
20     hiddenimports=[],
21     hookspath=['./hooks'],
22     hooksconfig={},
23     runtime_hooks=[],
24     excludes=[],
25     win_no_prefer_redirects=False,
26     win_private_assemblies=False,
27     cipher=block_cipher,
28     noarchive=False,
29 )
30 pyz = PYZ(a.pure, a.zipped_data, cipher=block_cipher)
31 
32 exe = EXE(
33     pyz,
34     a.scripts,
35     a.binaries,
36     a.zipfiles,
37     a.datas,
38     [],
39     name='run_app',
40     debug=False,
41     bootloader_ignore_signals=False,
42     strip=False,
43     upx=True,
44     upx_exclude=[],
45     runtime_tmpdir=None,
46     console=True,
47     disable_windowed_traceback=False,
48     argv_emulation=False,
49     target_arch=None,
50     codesign_identity=None,
51     entitlements_file=None,
52 )

其中{$YOURPYTHONENV}指的是你实际的python环境的路径,比如“C:/Python39”。

  • 通过命令“pyinstaller --onefile --additional-hooks-dir=./hooks run_app.spec --clean”生成可执行的exe文件,该exe文件会在dist文件夹中。最终的文件夹结构如下显示:
WORKINGDIR/
    - .streamlit/
        - config.toml
    - hooks/
        - hook-streamlit.py
    - app.py
    - run_app.py
    - run_app.spec
    - build/
        - run_app/
            - many .toc and .pyz
    - dist/
        - run_app.exe
  • 记住将.streamlit文件夹和app.py文件拷贝到dist文件夹中,这样在dist文件夹中执行exe文件时,不会报缺少文件的错误。

最后展示一下我的Streamlit应用的启动和显示界面。

 

posted @ 2023-02-23 13:35  IT磨刀石  阅读(5376)  评论(3编辑  收藏  举报