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

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

新規登録して質問してみよう
ただいま回答率
85.48%
マルチスレッド

マルチスレッドは、どのように機能がコンピュータによって実行したのかを、(一般的にはスレッドとして参照される)実行の複合的な共同作用するストリームへ区分することが出来ます。

Python

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

Q&A

解決済

1回答

2182閲覧

PySide2で複数のthreadを動かしたい。

mu_no

総合スコア15

マルチスレッド

マルチスレッドは、どのように機能がコンピュータによって実行したのかを、(一般的にはスレッドとして参照される)実行の複合的な共同作用するストリームへ区分することが出来ます。

Python

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

0グッド

1クリップ

投稿2020/07/05 02:27

#実現したいこと

ある部屋の入退室を管理する様なGUIアプリケーションを作るために、PySide2とQMLを使って、以下の様なコードを書きました。enterメソッド、exitメソッドは人が入室/退室したことを表現しており、部屋の人数を増減させます。

部屋の入退室をIoTデバイスを使って取得しようと考えているため、pythonでサーバーを立てて外部からHTTPリクエストを受け取る様に変更を加えたいと考えています。

import sys from PySide2 import QtCore, QtWidgets from PySide2.QtQml import QQmlApplicationEngine from PySide2.QtCore import QUrl class Connect(QtCore.QObject): def __init__(self): super().__init__() @QtCore.Slot(int, result=int) def enter(self, arg): return arg + 1 @QtCore.Slot(int, result=int) def exit(self, arg): if(arg == 0): return 0 else: return arg - 1 if __name__ == '__main__': app = QtWidgets.QApplication() myconnect = Connect() engine = QQmlApplicationEngine() bind = engine.rootContext() bind.setContextProperty("Connect", myconnect) engine.load(QUrl("Test1/Test1.qml")) sys.exit(app.exec_())

#試したこと
ひとまず以下の様にコードを変更して、HTTPリクエストを受け取ったら200を返すだけど簡単なpythonサーバーとGUIアプリケーションを別のスレッドで実行することを試しました。しかし、このコードを実行してもGUIアプリケーションは起動されるもののサーバーが立ち上がらず、HTTPリクエストが受け取れない様子でした。

import sys from PySide2 import QtCore, QtWidgets from PySide2.QtQml import QQmlApplicationEngine from PySide2.QtCore import QUrl import threading import http.server import socketserver import json class MyHandler(http.server.BaseHTTPRequestHandler): def do_POST(self): self.send_response(200) self.end_headers() class Connect(QtCore.QObject): def __init__(self): super().__init__() @QtCore.Slot(int, result=int) def enter(self, arg): return arg + 1 @QtCore.Slot(int, result=int) def exit(self, arg): if (arg == 0): return 0 else: return arg - 1 def runServer(): with socketserver.TCPServer(("", 80), MyHandler) as httpd: print("サーバーを起動します") httpd.serve_forever() def runGUIApp(): app = QtWidgets.QApplication() myconnect = Connect() engine = QQmlApplicationEngine() bind = engine.rootContext() bind.setContextProperty("Connect", myconnect) engine.load(QUrl("Test1/Test1.qml")) sys.exit(app.exec_()) if __name__ == '__main__': thread_1 = threading.Thread(target=runServer) thread_2 = threading.Thread(target=runGUIApp()) thread_1.start() thread_2.start()

#実現したいこと
PySide2を使う上で、GUIアプリケーションの裏側でサーバーを立ち上げていろいろな処理が行いたいです。今回は複数のthreadを動かすという手段を試みていますが、もしPySide2で素直に裏側の処理が書ける様な方法があればご教示いただけるとありがたいです。

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Pythonのスレッドを使うで良いと思います。

====

問題の原因:

thread_2 = threading.Thread(target=runGUIApp()) thread_1.start()

括弧があることに着目。

runGUIApp() はスレッドではなくメインスレッドで呼び出されています。
runGUIApp()内で GUI のイベントループが実行される為、
ウィンドウを閉じるまで後ろの thread_1.start() は実行されません。

解決策

python

1 thread_1 = threading.Thread(target=runServer, daemon=True) 2 thread_1.start() 3 runGUIApp()

GUIをメインスレッドで、threadを起動した後に実行します。

投稿2020/07/05 04:42

teamikl

総合スコア8664

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問