へっぽこプログラマーの備忘録
プログラムを中心とした個人的なメモ用のブログです。 タイトルは迷走中。
内容の保証はできませんのであしからずご了承ください。
menu
keyboard_arrow_up
Top
search
close
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
Home
›
Python
›
[PySide] QTimer の使い方
2023/03/28
[PySide] QTimer の使い方
update
event_note
label
PySide
label
Python
スレッドを使わずに定期的に GUI を更新するために、`QTimer` の使い方と挙動について簡単に調べてみました。
## 環境 - Python 3.8.10 - PySide 6.2.2.1 ## サンプルコード ```py import sys import time from datetime import datetime from PySide6.QtCore import (QTimer, Signal) from PySide6.QtWidgets import (QApplication, QWidget, QVBoxLayout, QLabel) class MainWindow(QWidget): """メインウィンドウ """ countup = Signal(int) def __init__(self, parent=None): super().__init__(parent) self.__count = 0 layout = QVBoxLayout() self.__label = QLabel(self.__current_count()) layout.addWidget(self.__label) self.setLayout(layout) self.__timer = QTimer(self) self.__timer.timeout.connect(self.__timeout) self.__timer.start(1000) self.__timer.singleShot(10000, self.__single_shot1) self.__timer.singleShot(15000, self.__single_shot2) def __timeout(self): self.__count += 1 print(f'{datetime.now()}, {self.__count}') self.__label.setText(self.__current_count()) #time.sleep(3) def __current_count(self) -> str: return f'現在のカウント: {self.__count}' def __single_shot1(self): print(f'{datetime.now()}, 10秒経過') def __single_shot2(self): print(f'{datetime.now()}, 15秒経過') if __name__ == "__main__": app = QApplication(sys.argv) main_window = MainWindow() main_window.show() ret = app.exec() sys.exit(ret) ``` ``` 2023-03-27 14:04:40.166652, 1 2023-03-27 14:04:41.115886, 2 2023-03-27 14:04:42.066937, 3 2023-03-27 14:04:43.026873, 4 2023-03-27 14:04:44.026648, 5 2023-03-27 14:04:45.026877, 6 2023-03-27 14:04:46.026574, 7 2023-03-27 14:04:47.026898, 8 2023-03-27 14:04:48.026477, 9 2023-03-27 14:04:49.027008, 10秒経過 2023-03-27 14:04:49.027169, 10 2023-03-27 14:04:50.027045, 11 2023-03-27 14:04:51.026868, 12 2023-03-27 14:04:52.027034, 13 2023-03-27 14:04:53.026916, 14 2023-03-27 14:04:54.026824, 15秒経過 2023-03-27 14:04:54.027010, 15 ``` ### 処理に時間がかかった場合はどうなる? 上記のコードでは、1秒ごとに `__timeout` 関数が実行されますが、もしその中で処理に時間がかかったとしたらどうなるか? 試しに3秒のスリープを入れてみました(上記のコメントアウトを解除)。 ``` 2023-03-27 14:07:10.458991, 1 2023-03-27 14:07:13.462465, 2 2023-03-27 14:07:16.464238, 3 2023-03-27 14:07:19.467192, 4 2023-03-27 14:07:22.470589, 10秒経過 2023-03-27 14:07:22.471410, 5 2023-03-27 14:07:25.475184, 6 2023-03-27 14:07:28.478740, 15秒経過 2023-03-27 14:07:28.480526, 7 2023-03-27 14:07:31.484492, 8 ``` 3秒経過後、すぐに `__timeout` がコールされています。 前の処理が完了しないと次の処理は行われないようです。
## 参考 URL - https://fereria.github.io/reincarnation_tech/11_PySide/01_PySide_Basic/00_Tutorial/13_timer/ - https://fereria.github.io/reincarnation_tech/11_PySide/00_Tutorial/13_timer/
tweet
facebook
Pocket
B!
はてブ
LINE
chevron_left
chevron_right
Translate
Popular Posts
Labels
.NET Core
31
.NET Framework
17
.NET Standard
2
AdminLTE
1
AI
1
Apache
3
AppVeyor
2
AsciiDoc
7
ASP.NET Core
55
Atom
4
AWS
5
AWS Cloud9
4
blockdiag
1
Blogger
13
Bootstrap
3
C/C++
6
C#
106
CentOS
3
Chrome
1
Chronograf
3
chrony
1
Codecov
1
CSS
1
Docker
82
DokuWiki
4
Doxygen
1
draw.io
1
EasyTag
1
Electron
1
Electron.NET
2
Entity Framework Core
9
Excel
2
FFmpeg
3
Firefox
6
Flask
1
Git
19
GitBook
4
GitBucket
7
GitHub
7
GitLab
39
Go
1
Google
1
Google Cloud Platform
1
Grafana
13
GStreamer
2
HTML
5
IIS
8
InfluxDB
14
JavaScript
15
Jekyll
3
Jenkins
7
Linux
34
Log4View
1
MahApps.Metro
3
MaterialDesignInXamlToolkit
1
MkDocs
2
MongoDB
5
MVC
1
MVVM
6
nginx
3
NLog
3
Node.js
8
npm
1
NVIDIA
3
onvif
1
OpenAPI
2
OpenCV
4
OpenSSL
3
OpenVINO
2
ownCloud
2
pandas
1
Pine Script
1
PlantUML
5
Portainer
3
PowerShell
8
Prism
2
PySide
19
Python
88
PyTorch
1
RabbitVCS
1
Razor
3
redis
1
Redmine
33
Redoc
1
remark.js
2
rocketchat
10
Ruby
3
scikit-learn
1
shotcut
1
SignalR
1
Slack
1
Socket.IO
1
SonarQube
5
Sphinx
10
SQL Server
5
SQLite
1
StableDiffusion
2
Subversion
2
Swagger
1
Swarmpit
1
Syslog
3
Telegraf
6
Tesseract
3
TestLink
2
Tomcat
2
TortoiseGit
11
TortoiseSVN
2
Trading View
1
Traefik
3
Travis CI
1
Ubuntu
31
Visual Studio
39
Visual Studio Code
10
VSCode
8
Vue.js
8
Windows
62
Windows 10
5
Windows ADK
1
Windows API
2
Windows Embedded
4
wkhtmltopdf
2
Word
3
WPF
12
WSL
5
WSL2
5
Xamarin
1
xUnit
5
yaml
1
yolo
1
アプリケーション
1
デザインパターン
1
テスト
1
バッチファイル
2
プログラミング
4
ライセンス
1
暗号資産(仮想通貨)
1
英語
2
確定申告
1
機械学習
1
強化学習
1
雑記
1
書籍
1
数学
1
正規表現
1
動画編集
1
Blog Archive
►
2024
(21)
►
12月
(3)
►
9月
(5)
►
8月
(1)
►
7月
(2)
►
6月
(1)
►
4月
(2)
►
3月
(1)
►
2月
(5)
►
1月
(1)
▼
2023
(30)
►
12月
(3)
►
11月
(5)
►
10月
(2)
►
9月
(1)
►
8月
(2)
►
7月
(4)
►
6月
(2)
►
5月
(3)
►
4月
(2)
▼
3月
(2)
[PySide] QTimer の使い方
Nginx の proxy_pass で名前解決されない
►
2月
(3)
►
1月
(1)
►
2022
(106)
►
12月
(5)
►
11月
(1)
►
10月
(3)
►
9月
(6)
►
8月
(7)
►
7月
(6)
►
6月
(13)
►
5月
(9)
►
4月
(15)
►
3月
(11)
►
2月
(14)
►
1月
(16)
►
2021
(85)
►
12月
(11)
►
11月
(6)
►
10月
(4)
►
9月
(10)
►
8月
(8)
►
7月
(4)
►
6月
(18)
►
5月
(7)
►
4月
(8)
►
3月
(2)
►
2月
(2)
►
1月
(5)
►
2020
(56)
►
12月
(1)
►
11月
(3)
►
10月
(3)
►
9月
(3)
►
8月
(3)
►
7月
(7)
►
6月
(7)
►
5月
(2)
►
4月
(6)
►
3月
(6)
►
2月
(3)
►
1月
(12)
►
2019
(92)
►
12月
(13)
►
11月
(9)
►
10月
(3)
►
9月
(2)
►
8月
(3)
►
7月
(5)
►
6月
(11)
►
5月
(6)
►
4月
(17)
►
3月
(9)
►
2月
(6)
►
1月
(8)
►
2018
(100)
►
12月
(1)
►
11月
(11)
►
10月
(8)
►
9月
(6)
►
8月
(10)
►
7月
(10)
►
6月
(8)
►
5月
(9)
►
4月
(8)
►
3月
(14)
►
2月
(4)
►
1月
(11)
►
2017
(117)
►
12月
(14)
►
11月
(20)
►
10月
(17)
►
9月
(19)
►
8月
(10)
►
7月
(8)
►
6月
(3)
►
5月
(6)
►
4月
(5)
►
3月
(2)
►
2月
(8)
►
1月
(5)
►
2016
(91)
►
12月
(5)
►
11月
(9)
►
10月
(11)
►
9月
(9)
►
8月
(6)
►
7月
(14)
►
6月
(14)
►
5月
(11)
►
4月
(10)
►
3月
(2)
►
2015
(23)
►
12月
(4)
►
11月
(2)
►
10月
(8)
►
9月
(8)
►
7月
(1)
►
2013
(3)
►
11月
(1)
►
9月
(1)
►
7月
(1)
►
2012
(2)
►
7月
(1)
►
6月
(1)
►
2011
(1)
►
9月
(1)
►
2009
(1)
►
7月
(1)
►
2008
(2)
►
11月
(1)
►
7月
(1)
►
2007
(3)
►
10月
(3)