質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.84%

  • Python

    6375questions

    Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

PyInstallerでexeファイル化する時にkivyのsoundloaderで音を読み込んでいると実行できない

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 705

isomiya

score 2

閲覧ありがとうございます。

kivyとPyInstallerを使いタイマーアプリを作ったのですが、exeファイルを起動しようとすると、「Falled to execute script main」と出てきて起動できません。

プログラムの最初でsoundloaderでmp3ファイルをを読み込んでいるのですが、それに関する記述をコメントアウトしたところ、問題なくexe化できました。ただ、それだと音が鳴らないので困っています。

どうすればエラーが出ずにexeファイル化できますか、または、exeファイルで音を出すにはどうすればいいですか?

環境
python 3.4.5
kivy 1.10.0 
PyInstaller 3.3.1

こちらのサイトを参考にexe化しました
https://www.closetoyou.jp/kivy/introduction-to-kivy16/

追記
下記のコードで試したのですが、やはりexe化の際にエラーがでてきます。

OS windows10

使用ファイル
・main.py 
・timer.kv
・default.mp3

>pyinstaller --noconsole main.py
>pyinstaller main.spec

from kivy.app import App
from kivy.uix.screenmanager import ScreenManager, Screen
from kivy.core.audio import SoundLoader
from kivy.resources import resource_add_path
import sys

if hasattr(sys, '_MEIPASS'):
    resource_add_path(sys._MEIPASS)

sm = ScreenManager()
endSound = SoundLoader.load('default.mp3')
endSound.volume = 0.1


class TimerScreen(Screen):

    def start(self):
        endSound.play()

    def stop(self):
        endSound.stop()


class TimerApp(App):

    def build(self):
        sm.add_widget(TimerScreen(name='time'))
        return sm


if __name__ == '__main__':
    TimerApp().run()
#:kivy 1.10.0
<TimerScreen>:
    BoxLayout:
        Button:
            text: 'start'
            on_press: root.start()
        Button:
            text: 'stop'
            on_press: root.stop()
# -*- mode: python -*-
from kivy.deps import sdl2, glew
block_cipher = None


a = Analysis(['main.py'],
             pathex=['D:\\Users\\UserName\\Documents\\kivy_project_files\\20180117 timer'],
             binaries=[],
             datas=[('default.mp3', '.'), ('timer.kv', '.')],
             hiddenimports=[],
             hookspath=[],
             runtime_hooks=[],
             excludes=[],
             win_no_prefer_redirects=False,
             win_private_assemblies=False,
             cipher=block_cipher)
pyz = PYZ(a.pure, a.zipped_data,
             cipher=block_cipher)
exe = EXE(pyz,
          a.scripts,
          exclude_binaries=True,
          name='main',
          debug=False,
          strip=False,
          upx=True,
          console=False )
coll = COLLECT(exe,
               a.binaries,
               a.zipfiles,
               a.datas,
               *[Tree(p) for p in (sdl2.dep_bins + glew.dep_bins)],
               strip=False,
               upx=True,
               name='main')
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

+1

コードとspecファイルがないので何とも言えないのですが、おそらく該当部分のパスにmp3ファイルがない(PyInstallerで生成時にmp3ファイルが取り込まれていない)ことが問題かと思われます。
参考のサイトをみるとPyInstaller実行時に–onefile を指定して一つのexeファイルにしているかと思います。
exe作成時に –onefile のオプションを外してexe化してみてください、そうするとdistフォルダが生成されれその中でdllなどがありますが、そのフォルダ内にmp3ファイルが取り込まれているかを確認してみてはいかがでしょうか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/01/17 21:56

    回答ありがとうございます。

    --onefileを外して実行してみたところ、pm3、kvファイル共にdictフォルダに入っていることが確認できたのですが、依然エラーが出てきます。

    キャンセル

  • 2018/01/18 05:58

    noconsole のオプションを外して実行してみると以下のエラーが表示されました

    ```
    File "kivy\lib\gstplayer\_gstplayer.pyx", line 233, in kivy.lib.gstplayer._gstplayer.GstPlayer.load
    kivy.lib.gstplayer._gstplayer.GstPlayerException: Unable to create a playbin
    [14664] Failed to execute script main
    ```
    こちらですが公式のIssueをみると上がっていてPyInsllerをアップデートすると解決するそうなので一度試してみてください。

    https://github.com/kivy/kivy/issues/5099

    キャンセル

  • 2018/01/19 13:26

    エラーですが、無事自己解決できました。
    親切に回答ありがとうございました。

    キャンセル

check解決した方法

0

main.pyの先頭行に
import os
os.environ["KIVY_AUDIO"] = "sdl2"

と記述した所、エラーなくexe化できました。

参考サイト
https://rabbitboots.com/blog/category/pyinstaller/
https://pyky.github.io/kivy-doc-ja/guide/environment.html

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.84%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Python

    6375questions

    Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。