環境
自分の環境
ProductName: Mac OS X
ProductVersion: 10.15.7
BuildVersion: 19H15
pyenv 2.0.0
Python 3.6.5
cxfreeze 6.6
動作しない配布先の環境
ProductName: Mac OS X
ProductVersion: 10.15.7
BuildVersion: 19H524
前提・実現したいこと
PythonでPySimpleGUIを使ったGUIプログラムをcx_freezeで実行ファイル化しました。
作成された.appファイルは自分の環境では動くものの、配布先のPCで起動しません。(友人エンジニアのPCでは動作しました…)
.appが動作しなかった配布先PCにて、myapp.appのパッケージ内容であるmyapp.app/Contents/MacOS/myapp
(実行ファイル)を起動してもらい、ターミナルに表示されたエラーを添付します。
エラーメッセージ
Last login: Thu May 20 13:13:34 on ttys001 You have new mail. /Users/HisName/Desktop/myapp.app/Contents/MacOS/main ; exit; The default interactive shell is now zsh. To update your account to use zsh, please run `chsh -s /bin/zsh`. For more details, please visit https://support.apple.com/kb/HT208050. (base) MacBook-Pro-2:~ HisName$ /Users/HisName/Desktop/myapp.app/Contents/MacOS/main ; exit; Traceback (most recent call last): File “/Users/MyName/.pyenv/versions/3.6.5/lib/python3.6/site-packages/cx_Freeze/initscripts/__startup__.py”, line 81, in run File “/Users/MyName/.pyenv/versions/3.6.5/lib/python3.6/site-packages/cx_Freeze/initscripts/Console.py”, line 36, in run File “main.py”, line 13, in <module> File “/Users/MyName/.pyenv/versions/3.6.5/lib/python3.6/site-packages/PySimpleGUI/__init__.py”, line 2, in <module> File “/Users/MyName/.pyenv/versions/3.6.5/lib/python3.6/site-packages/PySimpleGUI/PySimpleGUI.py”, line 104, in <module> File “/Users/MyName/.pyenv/versions/3.6.5/lib/python3.6/tkinter/__init__.py”, line 2116, in Tcl File “/Users/MyName/.pyenv/versions/3.6.5/lib/python3.6/tkinter/__init__.py”, line 2020, in __init__ _tkinter.TclError: Can’t find a usable init.tcl in the following directories: /usr/local/Cellar/tcl-tk/8.6.11_1/lib/tcl8.6 /Users/HisName/Desktop/myapp.app/Contents/lib/tcl8.6 /Users/HisName/Desktop/myapp.app/lib/tcl8.6 /Users/HisName/Desktop/myapp.app/Contents/library /Users/HisName/Desktop/myapp.app/library /Users/HisName/Desktop/myapp.app/tcl8.6.11/library /Users/HisName/Desktop/tcl8.6.11/library This probably means that Tcl wasn’t installed properly.
myapp.py
冒頭のみですみませんが、記載させていただきます
python
1# -*- coding: utf-8 -*- 2 3import base64 4import csv 5import datetime as dt 6import hashlib 7import hmac 8import io 9import json 10import os 11import pandas as pd 12import pathlib 13import PySimpleGUI as sg 14import random 15import requests 16from selenium import webdriver 17from selenium.webdriver.common.keys import Keys 18from selenium.webdriver.common.action_chains import ActionChains 19import shutil 20import socket 21import subprocess 22import sys 23import threading 24import time 25import traceback 26import urllib.parse 27import webbrowser 28from webdriver_manager.chrome import ChromeDriverManager 29 30#以下略
setup.py
python setup.py bdist_mac
として実行ファイルを作成する際の、setup.py
Python
1# -*- coding: utf-8 -*- 2 3import sys 4from cx_Freeze import setup, Executable 5 6copyDependentFiles = True 7silent = True 8base = None 9packages = [] 10includes = [ 11 'base64', 12 'csv', 13 'datetime', 14 'glob', 15 'hashlib', 16 'hmac', 17 'io', 18 'json', 19 'os', 20 'pandas', 21 'PySimpleGUI', 22 'random', 23 'requests', 24 'selenium', 25 'socket', 26 'sys', 27 'threading', 28 'time', 29 'traceback', 30 'urllib.parse', 31 'webdriver_manager.chrome' 32] 33 34 35excludes = [] 36 37base = None 38if sys.platform == 'win32': 39 base = 'Win32GUI' 40 41 42executables = [ 43 Executable('main.py', base=base) 44] 45 46 47bdist_mac_options = { 48 'custom_info_plist': 'Info.plist', 49} 50 51 52setup(name='myapp', 53 version='0.0', 54 options = { 55 'build_exe': { 56 'includes':includes, 57 'excludes':excludes, 58 'packages': packages 59 }, 60 'bdist_mac': bdist_mac_options 61 }, 62 executables=executables 63 ) 64
考察
pyenv環境でtkinterのGUIアプリを実行ファイル化した際に動作しないことへの対処方法などの記事は見つかりましたが、自分の環境(友人エンジニアのMacでも)正常に動作しているので、それらの記事とは何か違う対処が必要なのかと思います。
理解が足りないことは承知ではありますが、Pythonインストール時に同梱されている(?)tcl、tk(ってなんだろ…)を実行ファイル内に梱包し、利用できるように整備しないといけない…?みたいなニュアンスなのかな…?と思っています…
何かご意見いただけたら助かります。
必要な追記事項等ありましたらコメントいただければ随時追加しようと思います。
よろしくお願いします。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/07/12 14:28