###キー受付時に反応時間・反応キーが記録されません。
psychopyのコーダーでpythonを使用し、キー押し課題を作成しています。
①キー反応があった際にその反応を記録せよ、という指示を出しているつもりなのですが上手く通らず、キー反応がない時の記録ばかり出力されます。
②キー受付の際にエスケープキーが押された場合、プログラムを中断して画面を閉じる、という指示を出しているつもりなのですが、draw扱いになり次の画面に移って継続してしまいます。
###発生している問題
①下記のコードで、ループの最下部にあるresult出力の際、[(数字), (数字),'no response', 0]としか出力されません。
②エスケープキーを教えてもプログラムが中断されません。
###該当のソースコード
# -*- coding: utf-8 -*- from psychopy import visual, core, event, gui, data, misc from psychopy import parallel from psychopy.constants import * import gc, numpy, os, random, time, csv, cv2, codecs, sys, random, pdb try: results=[] datafile = [] #参加者IDの取得 try: expInfo=misc.fromFile('lastParams.pickle') except: expInfo={'Participant':''} expInfo['dateStr']=data.getDateStr() dlg=gui.DlgFromDict(expInfo,title='Experiment',fixed=['dateStr']) if dlg.OK: misc.toFile('lastParams.pickle',expInfo) else: core.quit() # 画面の準備 stimdir = 'C:\Users\hoge\Desktop\stim\st' myWin=visual.Window(fullscr=False,size=[800,800],monitor='Default',allowGUI=True,units='norm',color=(0,0,0)) trials = visual.TextStim(myWin, text = '',pos = (0,0), color = (-1,-1,-1)) # 条件のランダマイズの準備 trialList = range(0,30) for roopno in range(5): numpy.random.shuffle(trialList) #繰り返し for i in range(3): #とりあえず3試行やってほしいと設定してある #数字を出す diggits = ["1","2","3","4","6","7","8","9"] random.shuffle(diggits) diggits = map(str,diggits) stopwatch = core.Clock()# #ここから実際に表示していく trials.setText('+') trialStart = core.Clock() # while trialStart.getTime() <0.5: trials.draw() myWin.flip() stopwatch.reset() #図形を表示 trialsankaku = visual.ImageStim(myWin, image = stimdir+'\sankaku.png',pos = (0,0)) trialsankaku.draw() myWin.flip() core.wait(0.5) trials.setText('') cuestart = core.Clock() # while cuestart.getTime() <6.8: trials.draw() myWin.flip() #ここで数字が出る trials.setText(diggits[1]) trialStart = core.Clock() # while trialStart.getTime() <0.5: trials.draw() myWin.flip() blank = visual.TextStim(myWin, text = '',pos = (0,0), color = (-1,-1,-1)) blank.draw() myWin.flip() core.wait(6.8) event.clearEvents() stopwatch.reset() Responded=False #数字表示後のキー押し受付 while stopwatch.getTime < 1: if not Responded: Responded = event.getKeys(keyList=["f","j","escape"],timeStamped=stopwatch) if event.getkeys("escape"): myWin.close() core.quit() if not Responded: Responded =[("no response",0)] results = [trialList[roopno],diggits[1],Responded[0][0],Responded[0][1]] print(results) datafile = ("C:\Users\hoge\Desktop\stim\log") filename = open(os.path.join(datafile, expInfo['Participant'] + '_' + expInfo['dateStr'] + '.csv'),'ab') dataWriter = csv.writer(filename) filename.write('trialList,log,answer,RT,\n') dataWriter.writerows([results]) filename.close() except TypeError, e: print e
###試したこと
stopwatch=core.Clock, trialstart=core.Clock, cuestart=core.Clockの定義が重複しているのが影響しているかもしれないと思い、一度統一してみましたが特に変わりはありませんでした。

回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。