sleep.time()を使用して指定した間隔でデータを記録したいのですがうまくできません。
codeです。
python
1try: 2 while True: 3 accel_data = mpu.get_accel_data() 4 #x_angle = util.get_x_rotation(accel_data['x'], accel_data['y'], accel_data['z']) 5 y_angle = util.get_y_rotation(accel_data['x'], accel_data['y'], accel_data['z']) 6 7 if y_angle < normalMin: 8 motor.setDirection("stop") 9 else: 10 motor.setDirection("forward") 11 if y_angle >= mediumMin and highMin > y_angle: 12 motor.setPower("MEDIUM") 13 elif y_angle >= highMin: 14 motor.setPower("HIGH") 15 #sys.stdout = open("log.txt" , "w") 16 #print("Y_ANGLE", y_angle) #and ("X_ANGLE", y_angle) 17 #print("Y", y_angle) 18 #print( now) 19 20 #print(now.date()) 21 now = datetime.datetime.now() 22 print(now.strftime("\t %Y-%m-%d \t %H:%M:%S.%f")) 23 #print ("%0.2d:%0.2d:%0.2d" % (now.hour, now.minute, now.millis)) 24 #print(millis) 25 #print(process_time) 26 #print( x_angle) 27 accel_data = mpu.get_accel_data() 28 print( accel_data['x']) 29 #print(accel_data['y']) 30 #print( y_angle) 31 #print("Z", accel_data['z']) 32 """gyro_data = mpu.get_gyro_data() 33 print("Gx", gyro_data['x']) 34 print("Gy", gyro_data['y']) 35 print("Gz", gyro_data['z'])""" 36 # #print("Ax:{:.4f}\tAy:{:.4f}\tAz:{:.4f}\tGx:{:.4f}\tGy:{:.4f}\tGz:{:.4f} ".format(accel_data['x'], accel_data['y'], accel_data['z'], gyro_data['x'], gyro_data['y'], gyro_data['z'])) 37 time.sleep(1) 38 39finally: 40 #self.stop() 41 sys.stdout.close() 42 motor.clean() 43 44atexit.register(exitHandler) 45
このままではコードが読めないので、質問を編集し、<code>ボタンを押し、出てくる’’’の枠の中にコードを貼り付けてください
うまくできない、とはどういうふうにうまくできないんでしょうか。
また、それをどういうふうにしたいということでしょう。
14:08:46.719737
14:08:47.732011
14:08:48.741273
14:08:49.749938
14:08:50.761601
14:08:51.773069
いまこのような感じになっているのですが小数点以下の数字がずれているのでそれを合わせたいです。
それはこのコードではムリです
time.sleep(1)
で、いくら正確に1秒間の待ちができたとしても、それ以外のコードの実行時間で時間は経過し、ずれていきます
そこを正確に合わせたいという要求仕様なら、このようなコードではダメですね
ではどのようなコードをしようすればよろしいのでしょうか?
回答1件
あなたの回答
tips
プレビュー