ホチキス先生の「プログラマーと呼ばれたい」

InfoPath & SQL Server !

Archive for the ‘プログラミング’ Category

情報システムは内製することにより果実を得ることができる – 価値を生み出すのは「人」である

leave a comment »

情報システムは外注せず内製してこそ意味がある。その根本的な理由は、価値は人が生み出すものだからだ、ということだ。多くの組織はこのことを忘れ、人が生み出す価値を得ることなく金で解決しようとする。

先日こんな話を聞いた。知人が務める企業の顧客向けシステム、それは Web ベースのシステムで外注によって作られたものだが、元号が変わることで対応が必要となり、おおむね1億円の費用が必要だと言われているらしい。もしあなたが経営者だとして、この経費についてどのように考えるだろうか。払うのはあなただ。この経費が妥当なものか判断しなければならない。相手は誠実に正しい見積もりを提示しているのか、それとも足元をみてふっかけているのか。あるいはこの際、システムを別の業者に変えて作り直すことが良いのか。判断の材料は何だろう。自分に判断の材料がないならコンサルタントにアドバイスを求めるだろうか。俺ならこう思う。いまどき元号の変更に対応できないシステムは糞だ。よほどぼんくらなエンジニアでなければ、一瞬で新元号に対応できるように最初からシステムを作っているはずだ。ではなぜ1億円などという値をふっかけてきたのか。その業者は金を出せる顧客から取り、それを資金としてシステムの抜本的再構築を狙っているのだろう。そして他の顧客にはそこそこの値段で利用させる。システムを開発するには資金が必要だが、一度開発したシステムは売れば売るほどもうかる仕掛けになっている。ソフトウエアとはそういうものだ。

もうひとつの話がある。プログラマーを養成する学校の経営者とディスカッションしたときのことだ。日本では情報システムは外注することが多いが、欧米では外注がなくなりつつあり、およそ80%は内製によって運用されているらしい。そこで学校のプログラマーの養成カリキュラムも今後はシステムを売るSI屋向けではなく内製技術者として養成するものに変えていこうと考えている。なぜ情報システムが外注から内製に変わっているかというと、今の時代は情報システム自体が企業の根幹をなし価値を生むものであるから、外注することは価値を流出させてしまうという発想があるという。欧米では情報システムの80%が内製である、ということが事実かどうか俺に判断はできないが、情報システムは価値を生むものであるという視点は疑いようのない事実だ。

これらの話から得られる教訓は、プログラミングによって得られる果実を我が物にすることができるのは誰かということになる。改めていうまでもなく、優れた情報システムは大きな価値を生む。業務の流れを整理し、自動化し、間違いをなくし、定型業務を軽減して人のクリエイティブな時間を増やすことができる。さらに新しい発想で事業を行い、今までにないビジネスモデルを生み出すこともできる。そして情報システムを作るのはコンピュータではなくプログラマーだということだ。価値を生み出すのは人である。

システムを外注するということは、価値を生み出すプログラマーが外注先のシステム会社にいる。したがってプログラマーが生み出す果実を得るのはシステム会社だ。しかしシステムを内製すれば、プログラマーは社内にいることになり、果実を得るのは自社である。要するに、価値を生み出す人間を擁することが会社の発展につながるという極めて単純な構造である。ただ難しいのは、いまは多くの経営者にとってプログラミングとは何かがわからないために、プログラミングは特殊な能力を持つ天才にしかできないことだと思われたり、優れたプログラマーを雇うことの意味がわからないことだ。だからこそ、明日を担うすべての子供たちに質の高いプログラミング教育をしなければならない。日本の社会を担うあらゆる階層のリーダーがプログラミングについての知識を持たなければ、ハイエナのような反日外資に価値をさらわれ続ける暗黒の未来が待っている。

2017年12月27日

松本 吉生(まつもとよしお)
Microsoft MVP Data Platform

1961年京都に生まれ、神戸で幼少期を過ごす。大学で応用化学を学んだのち、理科教諭として高等学校に勤務する。教育の情報化が進む中で校内ネットワークの構築運用に従事し、兵庫県立明石高等学校で文部科学省の「光ファイバー網による学校ネットワーク活用方法研究開発事業」に携わる。兵庫県立西宮香風高等学校では多部整単位制の複雑な教育システムを管理する学籍管理データベースシステムをSQL ServerとInfoPath、AccessなどのOfficeソフトウエアによるOBA開発で構築・運用する。現在は兵庫県立神戸工業高等学校でC#プログラミング、IoTなどのコンピュータ教育を行う。2004年からマイクロソフトMVP(Microsoft Most Valuable Professional)を受賞し、現在14回目の連続受賞。2016年にマイクロソフト認定教育者(Microsoft Innovative Educator Experts : MIEE)を受賞。

広告

IoT 開発における Arduino ファミリーの優位性 – nodeMCU を使う理由

leave a comment »

IoT 開発のために主として Arduino ファミリーと呼ぶことができるマイコンボードを使っている。ここで「Arduino ファミリー」と言っているのは、オフィシャルな Arduino 開発環境である Arduino IDE を使って開発でき、物理的な仕様もほぼ Arduino に準じているものを指している。

IoT開発のためのマイコンボードについて考える – その必要な特性は何か – Raspberry Pi と Arduino

leave a comment »

現在、様々なマイコンボードが開発され生産、販売されており、それらは様々な用途に利用されているが、IoT 開発におけるマイコンボードに必要な特性は何だろう。

どこかに統計データがあるかもしれないが、現時点、2017年12月25日において、俺の日常的な感覚からすれば世界で最も利用されているマイコンボードは Raspberry Pi と Arduino だ。

Raspberry Pi の特徴は高性能であるということに尽きる。Raspberry Pi に最適化された OS Raspbianをインストールしてキーボードとモニタを繋げば普通の Linux PC として機能する。高機能であることの裏返しとして、OS をインストールしなければならない手間と価格が高いデメリットがある。たとえば Amazon で Raspberry Pi 3 Model B V1.2 国内正規代理店品の価格は 5,578 円だ。もうひとつ、Raspberry Pi の使いにくさとして A/D コンバータを持っていないことがある。アナログセンサを Raspberry Pi で使うには A/D コンバータを別途取り付けなければならない。ただし I2C などディジタル通信によるセンサも充実してきたので、これからはアナログ入力処理の必要は少なくなるかもしれない。ただマイコンボードや制御の学習のためにはアナログ入力処理ができたほうがいいだろう。

Arduino の特徴はオープンソースハードウエアであることだろう。回路設計が公開されており、だれでも電子部品を組み合わせて同じものを作ることができる。このために中国製を中心とする膨大なクローンが市場にあふれている。現在 Arduino を代表するモデル Arduino UNO R3 は Amazon で 999 円で手に入る。中国系のサイトでは 300 円だ。また互換品も多い。小型で Wi-Fi モジュールを搭載した WeMos D1 mini は俺のお気に入りだが、中国系サイトで 310 円から 350 円くらいだ。さらに Arduino UNO R3 は D/A コンバータを搭載しておりアナログ入力を処理できる。

データ処理はクラウドで行う時代になり、マイコンボードでは高度な処理を必要としない。したがって IoT でのマイコンボードの役割は、センサからデータを受け取りインターネットに送信することになるだろう。そのためにはセンサの値を読む I/O とともに、ネットワーク通信機能が必須になる。現時点では Wi-Fi が扱いやすいだろう。安定して動作すること、安価であることも重要だ。できるだけ多くのセンサを設置し、継続して大量のデータを収集することがビッグデータの時代には必要だ。壊れやすかったり単価が高ければ数多く設置することが難しい。そのためには高機能であることよりもシンプルな設計が望ましい。

もしマイコンボードにデータベースの機能を持たせたり、Web サービスなど高度な役割を持たせたいなら Raspberry Pi だろう。しかし単純にデータ収集を行うためなら Arduino だろう。ただ Arduino では通信処理において実装が難しいものもある。今一歩 Arduino が進化し、CPU や ストレージなどの機能が高くなれば IoT における主役として確固たる位置につけるはずだ。それを期待している。

2017年7月18日

松本 吉生(まつもとよしお)
Microsoft MVP Data Platform

1961年京都に生まれ、神戸で幼少期を過ごす。大学で応用化学を学んだのち、理科教諭として高等学校に勤務する。教育の情報化が進む中で校内ネットワークの構築運用に従事し、兵庫県立明石高等学校で文部科学省の「光ファイバー網による学校ネットワーク活用方法研究開発事業」に携わる。兵庫県立西宮香風高等学校では多部整単位制の複雑な教育システムを管理する学籍管理データベースシステムをSQL ServerとInfoPath、AccessなどのOfficeソフトウエアによるOBA開発で構築・運用する。現在は兵庫県立神戸工業高等学校でC#プログラミング、IoTなどのコンピュータ教育を行う。2004年からマイクロソフトMVP(Microsoft Most Valuable Professional)を受賞し、現在14回目の連続受賞。2016年にマイクロソフト認定教育者(Microsoft Innovative Educator Experts : MIEE)を受賞。

C# – 教科「情報」の授業で使うタイピングトレーニングのソフトを作っています。その 6。テキストボックスをリッチテキストボックスに変更。フォントサイズを変えることができるようにした。

leave a comment »

授業でタイピング練習をすると同時に、アジャイル的なアプリケーションの開発の実際を体験する目的で、自作のタイピングソフトを作って改良を重ねている。今回はやや大きめの変更を加えた。

ひとつは、例題に対して自分が入力した文字のどこが間違ったかを「〇〇文字目」と表示していたのだが、実際に間違った文字の色を変えるなど直感的にわかるようにしてほしい、という生徒からの要望だ。これは、たしかに、わかる。しかしテキストボックスでは文字装飾に限界があるので、テキストボックスをリッチテキストボックスに変更し、間違った文字の BackColor を変えるようにした。

間違った文字の位置は、文字列の比較で myStrCount に入っているので、それを利用して次のようなコードになる。

—————————————————————————————–

//スコアの値から間違った文字を赤く変える
richTextBox1.Select(myStrCount, 1);
richTextBox1.SelectionBackColor = Color.Red;

—————————————————————————————–

もうひとつの要望は、文字の大きさが小さいので自分で適度な大きさに変更できるようにしてほしい、というものだった。これもいいフィードバックだ。

そこでフォームに 2 つのボタンとトラックバー、文字の大きさのサンプルテキストボックスを加えた。ボタンにはフォントサイズを 1 ポイントずつ増減するコードを書き、フォントサイズの下限を 1、上限を 30 としてトラックバーを連結した。コードは次の通りだ。

—————————————————————————————–

int myFontSize; // フォントサイズを変数にする

// フォントサイズを増やすボタン
private void buttonFontSizeUp_Click(object sender, EventArgs e)
{
myFontSize++;
if(myFontSize > 30)
{
myFontSize = 30;
}
myFontSizeChange();
}

// フォントサイズを下げるボタン
private void buttonFontSizeDown_Click(object sender, EventArgs e)
{
myFontSize–;
if(myFontSize <1)
{
myFontSize = 1;
}
myFontSizeChange();
}

// フォントサイズを変更するメソッド
private void myFontSizeChange()
{
textBox2.Font = new Font(“MS UI Gothic”, myFontSize);
richTextBox1.Font = new Font(“MS UI Gothic”, myFontSize);
textBoxFontSize.Text = myFontSize.ToString();
trackBar1.Value = myFontSize;
}

// トラックバーのスクロールイベントに対するメソッド
private void trackBar1_Scroll(object sender, EventArgs e)
{
myFontSize = trackBar1.Value;
myFontSizeChange();
}

—————————————————————————————–

textInputProgram_006

textInputProgram_007_mid_640_480

2017年6月19日

松本 吉生(まつもとよしお)
Microsoft MVP Data Platform

1961年京都に生まれ、神戸で幼少期を過ごす。大学で応用化学を学んだのち、理科教諭として高等学校に勤務する。教育の情報化が進む中で校内ネットワークの構築運用に従事し、兵庫県立明石高等学校で文部科学省の「光ファイバー網による学校ネットワーク活用方法研究開発事業」に携わる。兵庫県立西宮香風高等学校では多部整単位制の複雑な教育システムを管理する学籍管理データベースシステムをSQL ServerとInfoPath、AccessなどのOfficeソフトウエアによるOBA開発で構築・運用する。現在は兵庫県立神戸工業高等学校でC#プログラミング、IoTなどのコンピュータ教育を行う。2004年からマイクロソフトMVP(Microsoft Most Valuable Professional)を受賞し、現在14回目の連続受賞。2016年にマイクロソフト認定教育者(Microsoft Innovative Educator Experts : MIEE)を受賞。

C# – 教科「情報」の授業で使うタイピングトレーニングのソフトを作っています。その 5。ユーザー ID を Active Directory から取得するようにした。

leave a comment »

教科「情報」の授業でタイピングソフトを自作して生徒実習をしている。このねらいは 2 つある。ひとつは、実際に使いやすいソフトウエアを使いたい、ということがある。特に生徒の実習データを Microsoft Flow に送信して集計しやすくする、ということがある。もう一つの目的は、ソフトウエア開発の実際を生徒に見せたい、ということだ。

いわゆる「ウォーターフロー型」の開発には限界があることが多く指摘されている。現代的なソフトウエア開発環境を最大限に活用するには、アジャイルと呼ばれる開発スタイルが望ましい。そこで教科「情報」の授業で自分が作ったソフトウエアを生徒に使わせながら、問題点や改善点を指摘させて次のバージョンに適用する、という手法でソフトウエア開発の実際を間接的に体験させるのだ。

そのためには、最初から完成されたソフトウエアを使わさない。最初はごく基本的な仕組みだけ作ったソフトウエアを使わせ、問題点や改善点を指摘することを演習とする。

様々な意見が生徒から出て興味深いのだが、これはまた別項でまとめることにする。今回のマイナーバージョンアップでは「学籍番号を入力するのが面倒だ」と「学籍番号を全角で入力してしまう間違いがおこる」ことを回避することを考えた。これは、システム管理をやっている者には常識的な実装になるが、ユーザー ID を Active Directory から取得することだ。これは一行のコードで実現できる。

——————————————————————————————-

myUserName = Environment.UserName;

——————————————————————————————-

そして取得したユーザー ID を gakuseID テキストボックスに表示する。

——————————————————————————————-

gakuseID.Text = myUserName;

——————————————————————————————-

ちゃんと取得することが確認できれば、学籍番号のテキストボックスの Enabled プロパティを false にし、書き換えられないようにする。

——————————————————————————————-

gakuseID.Enabled = false;

——————————————————————————————-

これで学生番号は間違いなく処理されるようになる。

2017年6月16日

松本 吉生(まつもとよしお)
Microsoft MVP Data Platform

1961年京都に生まれ、神戸で幼少期を過ごす。大学で応用化学を学んだのち、理科教諭として高等学校に勤務する。教育の情報化が進む中で校内ネットワークの構築運用に従事し、兵庫県立明石高等学校で文部科学省の「光ファイバー網による学校ネットワーク活用方法研究開発事業」に携わる。兵庫県立西宮香風高等学校では多部整単位制の複雑な教育システムを管理する学籍管理データベースシステムをSQL ServerとInfoPath、AccessなどのOfficeソフトウエアによるOBA開発で構築・運用する。現在は兵庫県立神戸工業高等学校でC#プログラミング、IoTなどのコンピュータ教育を行う。2004年からマイクロソフトMVP(Microsoft Most Valuable Professional)を受賞し、現在14回目の連続受賞。2016年にマイクロソフト認定教育者(Microsoft Innovative Educator Experts : MIEE)を受賞。

C# – 教科「情報」の授業で使うタイピングトレーニングのソフトを作っています。その 4。いつでも終了、開始ができるボタンのインタフェースを制御した。

leave a comment »

教科「情報」の授業で使うタイピングトレーニングのソフトを作っている。ここでマイナーチェンジをしたのは、ボタンの有効状態を制御したところだ。たとえば、次の画面は文字入力をトレーニングして「終了」のボタンを押し、かかった時間とスコアを表示したところだ。

textInputProgram_001_mid_640

ところがこの状態で「開始」のボタンが有効になっている。そこでこのまま「開始」をクリックして「終了」をクリックすると、一字も入力することなく結果が出てしまう。

textInputProgram_002_mid_640

そこで「開始」ボタンを押す前は「終了」と「リセット」を無効にし、「開始」ボタンを押せば「開始」ボタンは無効となり「終了」ボタンが有効になり、「終了」ボタンを押せば「終了」ボタンは無効となり「リセット」ボタンが有効となる、といったようにボタンの有効無効を制御することにした。

まずフォームの初期化で「終了」ボタンと「リセット」ボタンを無効にしておく。

——————————————————————————————

btnEnd.Enabled = false; //終了ボタンを無効にする
btnClear.Enabled = false; //クリアボタンを無効にする

——————————————————————————————

次に「開始」ボタンのクリックイベントで「開始」ボタンを無効にし「終了」ボタンを有効にする。

——————————————————————————————

btnStart.Enabled = false; //開始ボタンを無効にする
btnEnd.Enabled = true; //終了ボタンを有効にする

——————————————————————————————

そして「終了」ボタンのクリックイベントで「終了」ボタンを無効にし「クリア」ボタンを有効にする。

——————————————————————————————

btnStart.Enabled = false; //スタートボタンを無効にする
btnClear.Enabled = true; //リセットボタンを有効にする

——————————————————————————————

最後に「クリア」ボタンのクリックイベントで「クリア」ボタンを無効にし「開始」ボタンを有効にする。

——————————————————————————————

btnClear.Enabled = false; //クリアボタンを無効にする
btnStart.Enabled = true; //スタートボタンを有効にする

——————————————————————————————

これでボタンの有効無効管理ができた。

textInputProgram_003_mid_640

textInputProgram_004_mid_640

textInputProgram_005_mid_640

さて、このような制御をどこまですればよいのだろうか。それはプログラムを誰がどのように使うのかにかかっている。たとえばこのソフトウエアが、自分で文字入力のトレーニング結果を知りたいために使うのならば、このような制御を考える必要はないのかもしれない。自分の力を知るために「ずる」をする意味がないからだ。しかし、たとえば学校の授業で先生が生徒に課す場合は、少しでもよい結果を出すために「ずる」をしようと考える生徒がいるかもしれない。

そのことを考えると、たとえばテキストを別に入力しておき、ペーストするような「ずる」も考えられるかもしれない。使いやすさと同時に、想定外の利用をされないように考えることは、ソフトウエアの本来の機能とはまた別に、ソフトウエア開発のテーマである。

2017年6月16日

松本 吉生(まつもとよしお)
Microsoft MVP Data Platform

1961年京都に生まれ、神戸で幼少期を過ごす。大学で応用化学を学んだのち、理科教諭として高等学校に勤務する。教育の情報化が進む中で校内ネットワークの構築運用に従事し、兵庫県立明石高等学校で文部科学省の「光ファイバー網による学校ネットワーク活用方法研究開発事業」に携わる。兵庫県立西宮香風高等学校では多部整単位制の複雑な教育システムを管理する学籍管理データベースシステムをSQL ServerとInfoPath、AccessなどのOfficeソフトウエアによるOBA開発で構築・運用する。現在は兵庫県立神戸工業高等学校でC#プログラミング、IoTなどのコンピュータ教育を行う。2004年からマイクロソフトMVP(Microsoft Most Valuable Professional)を受賞し、現在14回目の連続受賞。2016年にマイクロソフト認定教育者(Microsoft Innovative Educator Experts : MIEE)を受賞。

Windows XP で Arduino IDE 1.8.2 をインストールして ESP8266 Community ボードパッケージを適用し、nodeMCU Amica にスケッチを書きこもうとするとエラーがおこる – bits フォルダに cxxabi_tweaks.h ライブラリを配置すると解消する。

leave a comment »

Windows XP Service Pack 2 のノートパソコンを使って Arduino の開発環境を整えようとしている。Arduino IDE はバージョン 1.8.2 を使い、インストールする。この状態で、オリジナルの Arduino UNO は開発することができ、また CH340 や CP210 の USB シリアル変換ドライバを適用すれば Arduino UNO のクローンも開発することができる。しかし、ボードマネージャを使って ESP8266 ボードパッケージをインストールしても、nodeMCU Amica や nodeMCU LoLin にスケッチを書きこもうとするとエラーが出て書き込めない。

Arduino_1.8.2_setup_004

このときのエラーは、以下のようなものになっている。

—————————————————————————————-

Arduino:1.8.2 (Windows XP), ボード:”NodeMCU 1.0 (ESP-12E Module), 80 MHz, 115200, 4M (3M SPIFFS)”

In file included from C:\Documents and Settings\user\Local Settings\Application Data\Arduino15\packages\esp8266\hardware\esp8266\2.3.0\cores\esp8266\abi.cpp:23:0:

c:\documents and settings\user\local settings\application data\arduino15\packages\esp8266\tools\xtensa-lx106-elf-gcc\1.20.0-26-gb404fb9-2\xtensa-lx106-elf\include\c++\4.8.2\cxxabi.h:50:32: fatal error: bits/cxxabi_tweaks.h: No such file or directory

#include <bits/cxxabi_tweaks.h>

^

compilation terminated.

exit status 1
ボードNodeMCU 1.0 (ESP-12E Module)に対するコンパイル時にエラーが発生しました。

「ファイル」メニューの「環境設定」から
「より詳細な情報を表示する:コンパイル」を有効にすると
より詳しい情報が表示されます。

—————————————————————————————-

このエラーからは、必要なライブラリがないことでコンパイルエラーになっていることがわかる。実際にフォルダを開くと、確かに必要なライブラリがない。

Arduino_1.8.2_setup_005

そこで、この「bits」フォルダに「cxxabi_tweaks.h」ライブラリをコピーする。「cxxabi_tweaks.h」ライブラリは、GitHub などから入手する。

Arduino_1.8.2_setup_006

Arduino_1.8.2_setup_007

Arduino IDE を再起動し、Blink のスケッチを書きこむとうまくいった。

Arduino_1.8.2_setup_002

Arduino_1.8.2_setup_008

2017年6月14日

松本 吉生(まつもとよしお)
Microsoft MVP Data Platform

1961年京都に生まれ、神戸で幼少期を過ごす。大学で応用化学を学んだのち、理科教諭として高等学校に勤務する。教育の情報化が進む中で校内ネットワークの構築運用に従事し、兵庫県立明石高等学校で文部科学省の「光ファイバー網による学校ネットワーク活用方法研究開発事業」に携わる。兵庫県立西宮香風高等学校では多部整単位制の複雑な教育システムを管理する学籍管理データベースシステムをSQL ServerとInfoPath、AccessなどのOfficeソフトウエアによるOBA開発で構築・運用する。現在は兵庫県立神戸工業高等学校でC#プログラミング、IoTなどのコンピュータ教育を行う。2004年からマイクロソフトMVP(Microsoft Most Valuable Professional)を受賞し、現在14回目の連続受賞。2016年にマイクロソフト認定教育者(Microsoft Innovative Educator Experts : MIEE)を受賞。

Written by Yoshio Matsumoto

2017年6月14日 at 10:50 AM