X

知識の倉庫の整理

はてなブログからワードプレスに引っ越しました。ここでは中小企業診断士の勉強記や経理、派遣社員として働いて気づいたこと、その他に技術関連や社会関連について思ったことを書いています。現在はAccessVBAを勉強中。

VBAのスケジュール表自動作成でSEやプログラマーのすごさを垣間見た気がした

VBAのスケジュール表自動作成というのは『続ExcelVBAのプログラミングのツボとコツがゼッタイにわかる本』にあるVBAで自動でできるようにしたスケジュール表のことです。

スケジュール表というと何となくたいしたことはないイメージがあります。自分も最初は「簡単なシステムなんだろうな」と思っていました。しかし本書の大きさは大型本サイズでさらに全部で430ページ程になるなどボリュームがあります。

ですから、「スケジュール表なんて簡単そうなのになんでこんなに分厚いんだろう・・・。」と不思議に思っていました。けれども本書をひととおり読んでみて、簡単なシステムといっても実際に手を使ってコードを入力していくことで学ぶものがたくさんありました。

今回はこのことについて思ったことを書いていってみます。

『続ExcelVBAのプログラミングのツボとコツがゼッタイにわかる本』を読むきっかけや目的

このブログではVBAというプログラミング言語のすごさやその効果について何度も書いてきました。それからVBAについて本格的に勉強を始めてからは『VBAエキスパート公式テキスト Excel VBA ベーシック』や『VBAエキスパート公式テキスト Excel VBA スタンダード』を読んだり、業務で本で学んだ知識を利用して簡単にプログラムをつくってきました。

ある程度時間が経ち、多少VBAというものがわかってきたので、もう少しまとまったシステムをつくってみたいと考えるようになりました。そこで手に取ったのが『続ExcelVBAのプログラミングのツボとコツがゼッタイにわかる本』です。

他にもVBAに関するまとまったシステムをつくる方法が書かれた本はいくつかあったのですが、他の本に比べて本書はVBAの公式テキストの内容に近いステートメントや関数が使われており、何より初心者がちょっとしたシステムをつくってみたいと思った時にそれ程難しくない内容だと感じました。

そういった経緯からVBAのツボとコツの本を選んだという次第です。

スケジュール表の簡単な概要

エクセル上でスケジュール表をつくるとなると、単純に年・月・日と曜日、そしてその日何をするかが書けるちょっとしたスペースがあるスケジュール表であればすぐにできそうなイメージがあります。

自分も最初は『続ExcelVBAのプログラミングのツボとコツがゼッタイにわかる本』でつくるスケジュール表というのはそんなイメージがあって簡単に出来るものだろうと思っていました。しかし実際つくるとなると全然違いました。

本書における「スケジュール表自動作成」のスケジュール表というのは基本的にエクセルのワークシート上において次のように表示されるようにしていきます。

  • A1セルに年度
  • A列に月
  • B列に日
  • C列に曜日
  • D列は少し幅を広げて、その何をするかのスペースにする
  • 土曜日、日曜日の休日と祝日に色をぬる

といった感じでつくっていきます。一見すると何の変哲もない簡単なスケジュール表に見えます。手作業とかオートフィルを使ってもそれほど難しくはないんじゃないか、何もVBAを使ってコードを入力していくまでもないように見えます。

しかし、このスケジュール表を自動作成できるようにするためには、様々な状況やパターンの想定、それによる機能の追加などが書かれており、そのために430ページというボリュームになっています。

ではもう少し具体的に、このスケジュール表自動作成にはどういった機能があって、それを実現するための方法にはどんなものがあるのかについて、次の項目以降でまとめていきます。

実際の仕事においてどのようにコードが入力されていくのか

スケジュール表自動作成というシステムをつくるためにどういった方法で進めていくのか、というのが本書においては次のように書かれています。

  • ブック新規作成
  • 期間とスケジュール欄の列幅を固定値で、月・日・曜日と罫線を描画
  • 指定した期間とスケジュール欄の列幅で、月・日・曜日と罫線を描画
  • 印刷範囲設定
  • 土日祝日のセル背景に色を付ける
  • フォーム化
  • エラー処理追加

パッとみるとそれほど難しくはないように思えますが、VBA初心者が勉強するうえではそうでもありません。上記の形で進んでいくのと並行して本書では主に以下の項目がVBAプログラミングで新たに学べるものとなっています。

  • 罫線の引き方
  • 日付関係の各種関数
  • 印刷範囲の設定方法
  • 変数のより高度な使い方
  • VBEのデバッグ機能の使い方
  • ファイル操作
  • 2次元配列の使い方
  • 組み込みダイアログの利用
  • スピンボタンやフレームなどのフォーム
  • エラー処理
  • 配列の要素数の操作
  • オリジナルのデータ型の定義

『VBAエキスパート公式テキスト Excel VBA スタンダード』にも書いていないことが結構あります。それと同時に本書を読み始めてから、「スケジュール表というと単純そうな感じがするけど、確かにこんな機能も考えられるよな」とか「こういった方法もあるんだな」といった感じでたくさんの気付きがありました。

本書ではスケジュール表自動作成というシステムをつくっていくという内容になっていますが、そのために「段階的につくりあげていく」というアプローチをとっています。その理由は次のように書かれています。

p.30

アプリケーションの規模が大きいということは、プログラミングで実装する機能の数が多かったり、1つの機能そのもののコード量が多かったりします。すると、コードの記述ミスなどによって不具合が発生する確率が上がり、それぞれの機能が最初から一発ですべて意図通りに動く確率が下がってしまいます。

Excel VBAでのアプリケーション制作において、アプリケーションの規模が大きくなればなるほど大切になるコツは、前作でも登場した「段階的に作り上げていく」です。

確かにそうだなと思いました。自分も職場でVBAを使って簡単なプログラムを作ったときは「今はまだそんなにコードは多くないけど、これが何千行、何万行にもなったらどうやって進めていけばいいんだろう」と考えていました。

確かに少しずつコードを入れていって、その都度動作を確認していった方が現実的です。本書ではこの「段階的に作り上げていく」という方法が一貫して使われています。

もう少し詳しく書くと、

一旦思いつくやり方でやってみる→ある程度つくったら見直しをしてもっと簡単に処理できるステートメントや関数へ修正→withステートメントを使って重複したコードをまとめていく、この繰り返しといった感じです。

なるほど、実際の仕事の現場でもたぶんこういった感じで進められているのでしょう。どんなステートメントや関数、機能があるのかという面もそうですが、実際の業務の進め方という面でもいろいろとイメージができて勉強になる本です。

デバッグとエラー処理

システムをつくるとなると、様々な状況を想定してデバッグやエラー処理も必要になってきます。自分は今まではプログラムは作ったら作りっぱなしで、その後「不具合が出たらどう処理するか」までは全然考えていませんでした。こういった面でも本書は勉強になります。

『VBAエキスパート公式テキスト Excel VBA スタンダード』ではデバッグやイミディエイトウィンドウなど簡単にしか説明されていないのですが、『続ExcelVBAのプログラミングのツボとコツがゼッタイにわかる本』では具体的にどういった場面でどの機能を使えばいいのかが書かれています。

「おっ」と感じた部分もたくさんあったのですが、その中のひとつがウォッチウィンドウを使う時にコードには記述されていないウォッチ式を追加して値を確認できる、といったものです。

説明するのは難しいのですが、実際の論理エラーを想定してそういった時はどうすればいいのかが詳しく書かれており、興味がある方は本書を見ていただければと思います。

本書はスケジュール表自動作成のエラー処理についても書かれています。その考え方として「自分がシステムをつくってもユーザーが意図通りシステムを使ってくれるとは限らない。時にはこちらが全く想定していない使い方をするかもしれない。そうなった時のためにも何らかの処理を準備しておく必要がある」といったものです。

確かに言われてみればそうだなぁと思いました。別にいたずらするつもりはなくても、何かの拍子で手が滑ってとんでもない数値を入れてしまったり、気づかずに全然違う値を入れてしまうという状況はあり得ます。

そうなった時のためにどんな対応方法が書かれているのかというのが本書のエラー処理の部分です。この部分もVBAで配列では対応できない場合はTypeステートメントを使う方法もある、といったことが書かれており学べる部分がたくさんあると感じました。

フォームモジュールやFunctionプロシージャの活用

『続ExcelVBAのプログラミングのツボとコツがゼッタイにわかる本』の中の一番の見所はたぶんここだと自分では感じています。第5章の「フォームから期間とデザインを指定可能にしよう」という所です。

VBAとかプログラミングと聞くと、単純に業務の自動化、ボタンを押したら何らかの処理が自動で行われるといったイメージがありますが、VBAにはそれだけではなく「フォームの作成」ができる機能があります。これがVBAの幅を広げているとも言えると思います。

この第5章ではフォームを使ってスケジュール表自動作成の開始日と終了日の設定、休日祝日のセルにどの色を使うかの選択などを設定できるようにしていくのですが、この部分ではどのようにコードを入れていくのかがすごく勉強になりました。

例えばこのフォームにこのコードを入れたらAという処理が実行されて、別のフォームに入れたBというコードはCに数値を入れたら処理が実行されるといった具合に、「処理がいろんな所を飛ぶ」のが、「あぁなんかシステムっぽいなぁ」と感じました。

会計ソフトとか実際に企業内で使われるようなシステムもおそらくこんな感じなのではないでしょうか。

本書の第5章を読んでいておもしろいと思ったのは、VBAで用意されているコンボボックスとかスピンボックスなどのフォームを使うだけではなく、「既にある色を選択できるダイアログボックス」なども利用できる点です。

これはエクセルの画面の上にあるリボンから手作業で開くのではなく、ちゃんとVBAでのコードを利用することで開いたり使えたりするのです。「あぁそういったやり方もあるのかぁ」とVBAとかエクセルというものが自分の中ですごく可能性というか使い勝手が広がっていくような感じがしました。

ワードプレステーマで使われるモジュールテンプレートの数

ここまで書いてきたように『続ExcelVBAのプログラミングのツボとコツがゼッタイにわかる本』を読むことで、システムというのはこんな感じなのかな、というなんとなくのイメージはできるようになってきました。

特にこのブログではワードプレスで「simplicity」というテーマを使っているのですが、システムの内部の構造までわかるものの中では身近にあるもののひとつです。

たぶんエクセルのVBAでコードを入力する場所としての「モジュール」にあたるものが、ワードプレスのテーマにおいて「モジュールテンプレート」というものに対応するのではないでしょうか。(間違えていたら許してください)

このブログで使わせていただいてるワードプレスのテーマが「simplicity」というものであり、わいひらさんという方が作成したものです。

で、その管理画面からカスタマイズ→テンプレートの編集でこのテーマで使われているモジュールテンプレートが100個程あります。親テーマとか子テーマとかいろいろ種類があるのですが、最も多いところでこのテーマを構成していると考えられるコードが書かれたモジュールが100個程あるということです。

何が言いたいかというと、本を見ながらではありますが実際にシステムをつくってみたことで、「simplicity」などの使いやすいテーマを作れるプロというのは本当にすごいと感じられるようになったのと、このレベルのテーマをつくるにはこれぐらいの規模のコードを書く必要があるんだなぁという点に気づいたということです。

今までの自分であれば、テーマの数とかモジュールテンプレートの数とか全然気にもとめていませんでした。

しかし、『続ExcelVBAのプログラミングのツボとコツがゼッタイにわかる本』を通して実際に自分の手でコードを入力していくことでその大変さに気づきました。だからこそこのブログのテーマのように、プロの方がつくるシステムがどれだけすごいのか、ということが少しですが理解できた気がします。

やっぱり実際に経験してみないとその凄さというのはわからないものです。もちろん全部を理解できたわけではありませんが。

コードの分量とかここにチェックマークをつけたらこのコードが反応してここに繋がってくるんだなとか、全然素人視点ではあるのですが想像を巡らせるとこれだけの複雑な構造を構築できる製作者の方というのはどれだけすごいのだろうか、と途方に暮れてしまいます。

以上のようなことからタイトルにもあるように、『続ExcelVBAのプログラミングのツボとコツがゼッタイにわかる本』を読んでみた感想と、本書を通してプログラマーとかSEとかその道のプロというのは本当に素晴らしいと感心したというお話です。

あわせて読みたい

こんな記事も読まれています

更新日 2019年8月17日 8:14 AM