私は6つのセンサーを使って6つの異なるファイルにデータを保存するプロジェクトを開発中です。別のSOの質問(https://stackoverflow.com/a/36634587/2615940)を介して、私はマルチプロセッシングモジュールが私のためにこれを行うことを学んだが、私の新しいコードを実行すると、6つではなく1つのファイルしか得られない。 ?Pythonマルチプロセッシングを使ったファイルの同時書き込み
*下記のskrrgwasmeの提案に基づいてManager
を含むようにファイルを編集しましたが、コードが実行されて何も生成されません。エラーもファイルもありません。ちょうど走る。
コード:
import Queue
import multiprocessing
import time
def emgacq(kill_queue, f_name, adcpin):
with open(f_name, '+') as f:
while True:
try:
val = kill_queue.get(block = False)
if val == STOP:
return
except Queue.Empty:
pass
an_val = ADC.read(adcpin) * 1.8
f.write("{}\t{}\n".format(ms, an_val))
def main():
#Timing stuff
start = time.time()
elapsed_seconds = time.time() - start
ms = elapsed_seconds * 1000
#Multiprcessing settings
pool = multiprocessing.Pool()
m = multiprocessing.Manager()
kill_queue = m.Queue()
#All the arguments we need run thru emgacq()
arg_list = [
(kill_queue, 'HamLeft', 'AIN1'),
(kill_queue, 'HamRight', 'AIN2'),
(kill_queue, 'QuadLeft', 'AIN3'),
(kill_queue, 'QuadRight', 'AIN4'),
(kill_queue, 'GastLeft', 'AIN5'),
(kill_queue, 'GastRight', 'AIN6'),
]
for a in arg_list:
pool.apply_async(emgacq, args=a)
try:
while True:
time.sleep(60)
except KeyboardInterrupt:
for a in arg_list:
kill_queue.put(STOP)
pool.close()
pool.join()
raise f.close()
if __name__ == "__main__":
main()
は、あなたがこれらの質問の両方のために対処してきた問題を考えると、私は強くあなたには、いくつかの基本的なPythonのチュートリアルを通過示唆しています。関数呼び出し、変数の代入、引数の受け渡しなどの基本的な考え方については混乱があるようです。あなたは、あなたが次のスクリプト/プログラムに飛び込む前に、それらの基礎を理解することができれば、より多くの成功を収めます。 – skrrgwasme