きょういく ユースフル! ~ 僕は触媒になりたい ~

全て | カテゴリ未分類 | 生活をよくする | 本の紹介 | 共に生き、共に育つ | たのしいべんきょう | 個人的な日記 | 体育 | 音楽♪ | 道徳 等 | 問題解決 | 考え方 | 話し合い・話す・聞く | 特別支援教育 | 小学校 | 阪神間 地域情報 | PC・デジタル関係 | 教材・教具 | 食育(自立生活・家庭科)・園芸 | 仕事術 | 旅行(温泉含む) | 英語学習 | 環境保護・エコ | 作文・書くこと・漢字 | よのなか(社会) | いのち | 人間関係・コミュニケーション | 子育て | 地震・防災 | 算数 | 心理・カウンセリング・セラピー | 読む・音読・朗読 | エクセルでのプログラミング | 北播丹波 地域情報 | 教員免許 | 教育改革 | 休校期間お役立ち情報 | 映画 等 | 創造性をはぐくむ | プレゼン | 通級 | 健康 | ゲーム
2018.08.22
XML
​​​​ 【Excelプログラミング講座】第9回です。

この講座では、 エクセル野球シミュレーション「ダイナミックベースボール」 のゲームプログラムを材料として、エクセルVBAでのプログラミングを初心者向けに解説していきます。



ダイナミック・ベースボールのページ

過去記事をまとめたサイト↓
▼​ エクセルプログラミング講座


前回は、条件分岐が複雑化すると何がどうなっているか分かりにくくなるので、
「ノートにすべての場合を書き出し、一目瞭然にしておく という話をしました。

お盆休みをはさんだので、もう忘れてますか?
前回 ​をもう1度見に行ってください。
(この連載記事にどれだけの需要があるのかは分かりませんが・・・)

さて、そんなふうにすべての場合を想定してプログラムを組んだとしても、
人間のやることですから、分岐によってはうまく作動せず、エラーになることが多いです。

エジソンも言いました。
失敗は成功の元。
プログラムのエラーは、あって当たり前。
そのエラーをすべて見つけて、ことごとく修正していくことによって、完成していくのです。

「ダイナミックベースボール」は公開後10年以上経ちますが、いまだにエラーが発見されます。
エラーを見つけることを デバッグ(バグとり) といいます。
ゲーム会社では、デバッグ専用の人たちが日夜テストプレイに明け暮れます。
一般ユーザーがどんな操作をするか分からないので、ありとあらゆることをやってみて、プログラムが誤作動しないかチェックするのです。



にかとまは、実は野球ゲームを作っています 」という僕のブログ記事に寄せられた実際のバグ報告を元に、紹介します。

【エラー内容】
・セーフティバントをした打者がアウトになった場合に
 打数が2増えてしまいます。

【エラー報告を聞いたときの思考】
・打者成績の細かいところまでよく見てくれてる!
・打数が1増えるべきところを2増えていると言うことは、二重に処理されているかな?
・セーフティバントをした後のプログラムの処理を順に追っていこう。

【デバッグの実際】
(1)再現を試みる

エラー報告のとおりに自分もやって、同じことが起きるかどうか、確認します。

今回のエラーの発生条件は、「セーフティバントをしたとき」なので、
再現が容易です。


確かに、打数が2増えていました。


(2)原因を突き止める

「バント」ボタンを押したときのプログラムは、
標準モジュール3 の 「バント」のところに書いてあります。



バント処理の最初の条件分岐は、ランナーの有無が条件。
セーフティバントとはランナーがない状態のバントなので、
記述をず~っと下に行くと、以下の箇所があります。

~~~~~~~~~~~~~~~~~~~~~~~~
MsgBox ("なんとセーフティバント~!!"), , "バント!"

Call SeisekiB(Range("H6"), 22)
~~~~~~~~~~~~~~~~~~~~~~~~

Call SeisekiB(Range("H6"), 22) の意味は、
  バッター成績反映のサブルーチン(SeisekiB)を呼び出し 
  DB_main.xlsの”H6"番地のセル=選手名を、
  DB_teamdata.xlsで検索し、22番目の列=「打数」を1増やす

すなわち、ここでいったん打数が1増えています。

その語の記述を追っていくと、
やはり!
Call SeisekiB(Range("H6"), 22)
という、 打数を1増やす命令がまた出てきました。




二重処理がめだたく見つかりました。
あとは、どちらかを削除すればいいわけです。

さて、どっちをとるか?

どっちをとってもいいのですが、
条件分岐の中の処理をとるよりも、条件分岐する前の処理をとったほうが
わかりやすいので、最初のをとることにします。



(3)プログラムを修正する

~~~~~~~~~~~~~~~~~~~~~~~~
MsgBox ("なんとセーフティバント~!!"), , "バント!"

Call SeisekiB(Range("H6"), 22)
~~~~~~~~~~~~~~~~~~~~~~~~

ここの、最初の 

Call SeisekiB(Range("H6"), 22)

というのを、消します。

これで、めだたくデバッグ終了!


(4)動作確認

本当にエラーが直っているかどうか、確認しなければいけません。
実際に「バント」ボタンを押し、セーフティバントを敢行して、打者成績への反映具合をチェックします。

直っていると、ほっとします。(^0^)


【今日のまとめ】 デバッグの手順
​​
(1)再現を試みる
(2)原因を突き止める
(3)プログラムを修正する

(4)動作確認

完璧主義の人は、こういうバグ取りにすんごい熱意を燃やして、バグがとれるたびに歓喜に打ち震えます。そして、デバッグの苦労が大きければ大きいほど、「完成した!」と思えたときの喜びも大きくなります。

テストプレイはとっても大事ですので、もちろん自分でも何度もプレイしてチェックするのですが、同じ人がデバッグすることには、限界があります。その人が考えもつかないことをやってくれることもありますので、なるべく他の多くの人にデバッグしてもらうようにしましょう。
身近にそういう人がいない場合は、未完成版の時点でネット公開し、デバッグ報告を多数の方から受け付けるのも一つの方法です。

さあ、あなたも、レッツ、デバッグ♪大笑い​​​





お気に入りの記事を「いいね!」で応援しよう

Last updated  2018.08.22 21:00:10
コメント(0) | コメントを書く


【毎日開催】
15記事にいいね!で1ポイント
10秒滞在
いいね! -- / --
おめでとうございます!
ミッションを達成しました。
※「ポイントを獲得する」ボタンを押すと広告が表示されます。
x

PR

Profile

にかとま

にかとま

Keyword Search

▼キーワード検索

Calendar

Archives

2024.09

© Rakuten Group, Inc.

Design a Mobile Website
スマートフォン版を閲覧 | PC版を閲覧
Share by: