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

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

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

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Python

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

Q&A

解決済

1回答

1831閲覧

起動したプロセスの終了を検出したい

chintao1224

総合スコア156

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Python

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

0グッド

0クリップ

投稿2020/04/10 05:05

編集2020/04/10 05:08

vs2017 communityを使っています。
osはwin7です。

C#のコードでpythonのコードを起動しています。
pythonにはログを書き込むようにしています。

以下のようなコードで起動しています。

c#

1 private void doPythonScript(string[] args, string planDateTime, string site, string method) 2 { 3 string doDateTime = string.Empty; 4 string result = string.Empty; 5 string errorInfo = string.Empty; 6 7 toolStripStatusLabel1.Text = "スクレイピング中です..."; 8 9 Process process = new Process(); 10 process.StartInfo.UseShellExecute = false; 11 process.StartInfo.RedirectStandardInput = true; 12 process.StartInfo.RedirectStandardOutput = true; 13 process.StartInfo.RedirectStandardError = true; 14 process.StartInfo.CreateNoWindow = true; 15 process.EnableRaisingEvents = true; 16 process.SynchronizingObject = this; 17 18 process.OutputDataReceived += (sender, e) => 19 { 20 try 21 { 22 if (!process.Responding) 23 { 24 if (process.HasExited) 25 { 26 var s = process.StandardError.ReadToEnd(); 27 if (s.Length == 0) 28 { 29 doDateTime = DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss"); 30 result = "成功"; 31 errorInfo = string.Empty; 32 } 33 else 34 { 35 doDateTime = DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss"); 36 result = "失敗"; 37 errorInfo = s; 38 } 39 upsertData(planDateTime, doDateTime, site, method, result, errorInfo); 40 lvwSchedule.SelectedItems[0].SubItems[1].Text = doDateTime; 41 lvwSchedule.SelectedItems[0].SubItems[4].Text = result; 42 lvwSchedule.SelectedItems[0].SubItems[5].Text = errorInfo; 43 44 toolStripStatusLabel1.Text = string.Empty; 45 46 readLogFile(); 47 } 48 } 49 } 50 catch (InvalidOperationException os) 51 { 52 string s = os.Message; 53 } 54 }; 55 56 process.Exited += delegate 57 { 58 upsertData(planDateTime, doDateTime, site, method, result, errorInfo); 59 lvwSchedule.SelectedItems[0].SubItems[1].Text = doDateTime; 60 lvwSchedule.SelectedItems[0].SubItems[4].Text = result; 61 lvwSchedule.SelectedItems[0].SubItems[5].Text = errorInfo; 62 63 toolStripStatusLabel1.Text = string.Empty; 64 65 readLogFile(); 66 }; 67 68 process.StartInfo.FileName = "python"; 69 process.StartInfo.Arguments = string.Join(" ", args); 70 71 process.Start(); 72 process.BeginOutputReadLine(); 73 74 bool hasProcessExited = process.WaitForExit(1000); 75 process.Close(); 76 }

pythonが起動され終了するには分かっています。
ログに書き込まされているのを確認しました。

どうしても終了を検出できず、ステータスバーのテキストをクリアしたり、dbに書き込んだりログを読み込んだりできません。

終了時にステータスバーのテキストをクリアしたり、dbに書き込んだりログを読み込んだりしたいのですが、プロセスの終了を検出できません。

どうすればよいのでしょうか。
非同期で終了コードを検出することはできるのでしょうか。

よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

下のコードで、test.pyにはsys.exit(999)を記述していますが、実行すると
ExitCode = 999
が表示され、特に問題なく終了コードを取得出来ています。
プロセスが本当に終了しているかどうか、問題を切り分ける必要があるかもしれません。

C#

1 static void Main(string[] args) 2 { 3 Task.Run(() => 4 { 5 using (var proc = Process.Start("python", "c:/test/test.py")) 6 { 7 proc.WaitForExit(); 8 Console.Write("ExitCode = " + proc.ExitCode); 9 } 10 }); 11 Console.ReadLine(); 12 } 13

投稿2020/04/10 06:07

編集2020/04/12 03:40
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問