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

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

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

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

Q&A

解決済

1回答

781閲覧

python で、queueをsubprocessの引数にして実行したい

alizona

総合スコア126

Python

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

0グッド

1クリップ

投稿2022/07/31 05:21

編集2022/07/31 07:58

subprocess を使って、 python のプログラムを3度実行するのですが、その際に3つのプログラムから一つのqueueを参照したいです。
引数でqueueを送ろうとしたのですが、エラーになります。
どのようにすれば、queueをsubprocessの引数にできるのでしょうか?
アドバイスいただきたいです。

solved_code.py

1import queue 2import threading 3import time 4 5def login(queue, driver_num): 6 while True: 7 task = queue.get() 8 time.sleep(2) 9 queue.task_done() 10 print(f'driver{driver_num} : task{task}') 11 12queue = queue.Queue() 13for driver_num in range(1,4): 14 thread = threading.Thread(target=login, args=(queue, driver_num,), daemon=True) 15 thread.start() 16 17f=open('data.txt') 18data_list=f.read() 19for data in data_list.split('\n'): 20 if data!='': 21 queue.put(data) 22queue.join()
import subprocess import queue screenshot_home_queue=queue.Queue() f=open('data.txt') data_list=f.read() f.close() for data in data_list.split('\n'): screenshot_home_queue.put(data) cmd='python test.py 1 {}'.format(screenshot_home_queue) subprocess.Popen(cmd +'&',shell=True) subprocess.Popen(cmd +'&',shell=True) subprocess.Popen(cmd +'&',shell=True)
/bin/sh: -c: line 0: syntax error near unexpected token `newline' /bin/sh: -c: line 0: `python test.py 1 <queue.Queue object at 0x7fe2dbd8e370>'

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

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

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

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

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

guest

回答1

0

ベストアンサー

ターミナル画面で、このcmd変数の内容をタイプしてそれが実行できるのかを確認されてはどうでしょうか

投稿2022/07/31 05:29

y_waiwai

総合スコア87747

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

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

alizona

2022/07/31 05:32

queueはターミナル上で作成できるのですか?
y_waiwai

2022/07/31 06:03

それで実行できないとあなたがお考えなら、そのエラーメッセージもその対処法ってのも自明なのでは
alizona

2022/07/31 06:12

その場合、3つの実行されたpython programから一つのqueueを参照したい場合は、どのようにすればいいのでしょうか? queueクラスを作り、関数内でqueueをgolobalで作成して、python porguramから、アクセスしようとしたのですが、global変数でも複数のpython programの中では共有できませんでした。
alizona

2022/07/31 07:24

tes.py を subprocessで呼び出すのではなく、python でthreadingを使って、test()を呼び出すことにしました。 ありがとうございました。
alizona

2022/07/31 10:07 編集

#-------------------------------------------------------test.py------------------------------------------------------- import queue import threading import time queue=queue.Queue() def login(driver_num, q): while not q.empty(): task = q.get() #q.task_done() print(str(task) + ' : '+str(driver_num)) time.sleep(5) def create_thread(driver_num): thread = threading.Thread(target=login, args=(driver_num,queue,)) thread.start() def init(): global queue for num in range(1,11): queue.put(num) create_thread(1) create_thread(2) #queue.join() #-------------------------------------------------------manage.py------------------------------------------------------- from test import create_thread from test import init import time init() time.sleep(10) create_thread(3)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問