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

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

新規登録して質問してみよう
ただいま回答率
85.35%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python

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

Q&A

解決済

1回答

2425閲覧

csvに出力し続ける方法を知りたいです.

tazaryu

総合スコア6

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python

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

0グッド

1クリップ

投稿2020/12/30 06:59

得られるデータを連続して,csvに出力し続けたいのですが,1つのデータしか出力されないです.
データを得るたびに追記したいのですが(列ごとに),更新されたしまい,データが最初の1個しか出力されないので直したいです.
データ(emg64)は64個の数字列で;で区切られています.
3;4;5;5;..........;4;5 (64個)
毎回データを更新せずに,追記し続けていく方法をどなたか,ご教示の程お願い致します.

from collections import deque from threading import Lock import myo import pandas as pd import csv import numpy as np class MyListener(myo.DeviceListener): def __init__(self, queue_size=8): self.lock = Lock() # création de listes optimisées pour seulement ajouter des éléments self.emg_data_queue = deque(maxlen=queue_size) self.orientation_data_queue = deque(maxlen=queue_size) self.acceleration_data_queue = deque(maxlen=queue_size) self.gyroscope_data_queue = deque(maxlen=queue_size) self.rssi_data_queue = deque(maxlen=100) self.pose = myo.Pose.rest # pose quelconque self.connected = False # non connecté self.battery_level = 100 # niveau de batterie maximal self.emg_enabled = False # on acquiert pas les EMG self.locked = False # myo non vérouillé self.rssi = None # aucune valeur de force du signal bluetooth self.emg = None # données null des emg self.device_name = None # pas de nom du myo self.device = None self.myo_firmware = None self.arm = None self.x_direction = None self.sync = None def on_paired(self, event): """ méthode appelée si le myo est appareillé """ if __name__ == '__main__': print('paired') else: pass def on_unpaired(self, event): """ méthode appelée si le myo n'est plus appareillé """ if __name__ == '__main__': print('unpaired') else: pass def on_connected(self, event): """ méthode appelé si le myo est connecté """ self.device = event.device # sauvegarde de l'instance au myo arm event.device.unlock() # demande de desappareiller event.device.lock() # demande d'appareiller (génère des vibrations) event.device.stream_emg(True) # lance l'acquisition des emg self.connected = True # mise à jour du flag de connection du myo self.device_name = event.device_name # on récupère le petit nom du myo # on récupère également le numéro du firmware (non exploité dans l'UI) self.myo_firmware = '.'.join(map(str, event.firmware_version[:-1])) def on_disconnected(self, event): """ méthode appelée si le myo est déconnecté """ self.connected = False # flag mis à jour def on_arm_synced(self, event): """ méthode appelé si un bras est synchronisé pas vraiment compris !!! """ self.sync = True self.arm = event.arm # informe de la latéralité du bras détecté # informe de l'orientation du bracelet # (vers le poignet ou vers le coude) self.x_direction = event.x_direction if __name__ == '__main__': print(self.x_direction) else: pass def on_arm_unsynced(self, event): """ méthode appelée si le bras est désynchronisé pas vraiment compris !!! """ self.sync = False if __name__ == '__main__': print(f'arm unsynced : {event.arm}') else: pass def on_unlocked(self, event): """ méthode appelée si le myo est dévérouillé """ self.locked = False # flag mis à jour def on_locked(self, event): """ méthode appelée si le myo est vérouillé """ self.locked = True # flag mis à jour def on_pose(self, event): """ méthode appelée dès qu'une pose gestuelle est reconnue a) Spread b) Fist c) Wave in d) Wave out e) Double Tap f) Rest """ self.pose = event.pose # attribut mis à jour def on_orientation(self, event): """ méthode appelée pour récupérer a) orientation b) gyroscope c) accéléromètre d) associé à un timestamp """ with self.lock: self.orientation_data_queue.append((event.timestamp, event.orientation)) self.gyroscope_data_queue.append((event.timestamp, event.gyroscope)) self.acceleration_data_queue.append((event.timestamp, event.acceleration)) def on_rssi(self, event): """ méthode appelée suite à la réponse d'une requête "request_rssi()" """ with self.lock: # mise à jour de la liste self.rssi_data_queue.append(-event.rssi) def on_battery_level(self, event): """ méthode appelée dès que le niveau de batterie évolue """ self.battery_level = event.battery_level # mise à jour de l'attribut def on_emg(self, event): """ méthode appelée pour réceptionner les données EMG avec son timestamp """ with self.lock: self.emg_data_queue.append((event.timestamp, event.emg)) def on_warmup_completed(self, event): """ méthode appelée quand le myo arm est "chaud" c'est à partir de ce moment que les données sont les plus stables mais ça reste à vérifier pas vraiment pris en compte dans ce code (à faire évoluer) """ event.device.stream_emg(True) # lancement de l'acquisition EMG self.emg_enabled = True # mise à jour du flag def get_emg_data(self): """ méthode pour récupérer les données EMGs """ with self.lock: return list(self.emg_data_queue) def get_orientation_data(self): """ méthode pour récupérer les données d'orientation """ with self.lock: return list(self.orientation_data_queue) def get_gyroscope_data(self): """ méthode pour récupérer les données du gyroscope """ with self.lock: return list(self.gyroscope_data_queue) def get_accelerometor_data(self): """ méthode pour récupérer les données de l'accéléromètre """ with self.lock: return list(self.acceleration_data_queue) if __name__ == '__main__': # permet de tester sans interface graphique #import os from time import sleep myo.init(bin_path=r'C:\Users\name\Desktop\myo-sdk-win-0.9.0\bin') HUB = myo.Hub() LISTENER = MyListener() with HUB.run_in_background(LISTENER.on_event): emg_buffer = [] while True: print(LISTENER.emg_data_queue) if LISTENER.emg_data_queue: emg_buffer.extend([e[1] for e in LISTENER.emg_data_queue]) LISTENER.emg_data_queue.clear() if len(emg_buffer) >= 8: emg64 = [';'.join(map(str, sum(emg_buffer[:8], []))) + ';'] np.savetxt("tazawa.csv", emg64, fmt="%s", delimiter=",") emg_buffer = emg_buffer[8:] if len(emg_buffer) > 8 else [] sleep(0.1)

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2020/12/30 07:06 編集

後段にある print(LISTENER.emg_data_queue) の出力内容を記載してください。 現状のcsv出力と、期待する出力を記載してください。
tazaryu

2020/12/30 09:34

print(LISTENER.emg_data_queue) deque([(1609320624604962, [10, 5, 2, -2, 0, 0, 3, 7]), (1609320624604962, [-17, 3, 3, -3, -5, 0, 2, -3])], maxlen=8)です. この行列を8列分連結して,64個の数字列にします. その後,得られたデータ分だけ,csvに追記したいです. 1;2;3;4;........;64のようにです. 現状は最初の64個の数字列だけ出力され,次の値が追記されるのではなく,最初の1列が更新されるだけになってます.
guest

回答1

0

ベストアンサー

savetxt() はファイル名だけでなくファイルオブジェクトでも呼ぶことができるので追記モードで開いたファイルオブジェクトを渡してあげましょう。

Python

1with open("tazawa.csv", "a") as f: 2 np.savetxt(f, emg64, fmt="%s", delimiter=",")

【Numpy】savetxt()をappendモードで呼び出す - Qiita

投稿2020/12/30 07:09

A_kirisaki

総合スコア2853

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問