種別[statuses] cocolog:92875018
セクションJRF のひとこと
日時2021年07月13日
元URLhttp://jrf.cocolog-nifty.com/statuses/2021/07/post-af8d54.html

Windows の Python で signal.signal を使って…

Windows の Python で signal.signal を使って Ctrl-C (SIGINT) でデバッガに入るような処理を書こうと思ったのだがうまくいかない。
JRF 2021年7月13日

(「グローバル共有メモ」で書いたことのほぼコピペ。日本語でググっても良い情報がないので、こちらにも書いておく。)

JRF 2021年7月13日

実は下記のようなエラーが出ているのだが、最初のころから出ていたため、これが普通だと思っていた。

JRF 2021年7月13日

<pre>
forrtl: error (200): program aborting due to control-C event
Image              PC                Routine            Line        Source

libifcoremd.dll    00007FFFAD7D3B58  Unknown               Unknown  Unknown
(…)
QObject::~QObject: Timers cannot be stopped from another thread
</pre>

JRF 2021年7月13日

このエラーで、ググると、Python 2.7系から scipy などにあるエラーらしい。私は Python 3.7 系でも直っておらずこのエラーが続いていた。

JRF 2021年7月13日

《Ctrl-C crashes Python after importing scipy.stats - Stack Overflow》  
https://stackoverflow.com/questions/15457786/ctrl-c-crashes-python-after-importing-scipy-stats

↑によって、

JRF 2021年7月13日

<pre>
import os
os.environ['FOR_DISABLE_CONSOLE_CTRL_HANDLER'] = '1'
from scipy.stats import zscore
</pre>

JRF 2021年7月13日

…となどとすることで解決した。scipy モジュールなどを読み込む前に os.environ[...] = '1' が必要なのがミソらしい。

JRF 2021年7月13日