パイプでサブプロセスを使用する
subprocess.check_output() を利用することは、コマンドをパイプするための貴重なツールとなり、複雑な処理を可能にします。ただし、パイプ処理を容易にするためにshell=True引数を使用することは、セキュリティ上の懸念があるため、強くお勧めできません。
より安全で安定したアプローチとして、コマンドごとに個別のプロセスを作成し、コマンド間で出力をパイプ処理することを検討してください。以下に例を示します。
import subprocess # Create a subprocess for the ps command ps = subprocess.Popen(('ps', '-A'), stdout=subprocess.PIPE) # Create a subprocess for the grep command output = subprocess.check_output(('grep', 'process_name'), stdin=ps.stdout) # Wait for the ps process to finish ps.wait() # Process the grep output (if necessary)
または、str.find を使用して subprocess.check_output(('ps', '-A')) の出力で "process_name" を検索することで、パイプを完全に回避することもできます。 :
import subprocess # Run the ps command and capture the output output = subprocess.check_output(('ps', '-A')) # Search for "process_name" in the output if "process_name" in output: # Take appropriate action
これらのガイドラインに従うことで、維持しながらサブプロセス モジュールでパイプを効果的に利用できます。セキュリティと安定性。
以上がPython の「subprocess」モジュールでパイプを安全に使用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。