授業計画書 5.変数・関数の定義と使用 変数の型や概念、および関数の定義・使用方法についての理解 5.1 確認・提出事項 第四回目のレポート提出 5.2 授業内容 プログラムの基本構造 変数の概念、定義 簡単なプログラムの作成 5.3 プログラムの基本構造 (教科書 pp.24~25) プログラムの流れ コメント 5.4 変数・定数 変数・定数の型と定義(教科書 pp.26~31、p46) プログラム内における計算 5.5 VBA によるセルの操作(教科書 pp.132~133) セルへのデータの入力、セルからの取得(cells 命令) 5.6 IF 文による条件判断 IF 文による変数の判定 5.7 レポート課題 ※授業用資料、レポート課題等は http://ace.cen.kagoshima-u.ac.jp/bunseki/proex/proex.htm にアップロードしてあります。 ☆質問などはメールでも受け付けます([email protected]) 余談 ・世界最初のプログラマとも云われる オーガスタ・エイダ・バイロン(エイダ・ラブレス) ・マイクロソフト社のホログラムステッカーに 彼女の肖像が使われている ・プログラム言語「Ada(エイダ)」の語源 ・コンピュータの父と呼ばれるジョン・フォン・ ノイマン (ストアードプログラム方式の開発者) ・現代のコンピュータは「ノイマン型コンピュータ」 と呼ばれる。 Fパネルの70番リレー リレー中に「蛾」がいた 実際にバグが見つかった最初のケース 「世界で最初のコンピュータ」 グレース・ホッパー女史によるバグ報告書 と呼ばれるENIACの写真 (コンピュータ ハーバード・マークIIから採取) ※リレー(リレー回路) ・初期のコンピュータは数万個の真空管と 機械的にスイッチでOn-Offを切り替える回路 リレー回路で構成されていた。 参考文献(Wikipediaはアドレス省略) ・ENIACは内部では10進法で計算が行われていた。 Wikipedia:エイダ・ラブレス、ジョン・フォン・ノイマン、Harvard Mark I、バグ ENIAC http://www.wizforest.com/OldGood/eniac/ 5.変数・関数の定義と使用 【プログラムの基本構造】 ●参考書pp.24~25 Sub 足し算() 【プロシージャ名】プログラムの名前。全角日本語もOK。 'A1に入っている数値の回数だけbに1を足して、最後に2倍にする。 '最終的な計算結果はA1に入っている数値の2倍になる。 'その結果をA2に出力する。 ' Dim a As Integer '変数の型の宣言 Dim b As Integer '整数だけを扱うのでInteger型が適切 Dim i As Integer b = 0 a = Cells(1, 1).Value '変数bへの値の入力(bの初期化) 'セルA1からの値の取得 If a = 0 Then Exit Sub 'セルA1が空白や0だったら終了 For i = 1 To a b = b + 1 Next 'iの内容が1~aまでbに1を足す。 '(bに1をa回足す) b = b * 2 'bの内容を2倍にする。 Cells(2, 1).Value = b 'セルA2に計算結果を出力。 End Sub 【コメント】 プログラムを読みやすく するために、簡単に内容や 意味を説明するもの。 '(シングルクォーテーション)の右側が コメントとして扱われる ※プログラムの間違いを バグと呼び、バグを直す ことをデバッグと呼ぶ。 バグを出さないためには、 変数の定義、コメントに よる内容の明示、字下げ による命令ブロックの明示 などが有効である。 【プロシージャ】 Sub~End Subに囲まれた部分。 プログラムはこの範囲で『上から下に』実行される。 ※従って、記述する順序を間違えると正常に動作しない場合が多い。 ※上のサンプルプログラムはこれから習得する要素のほとんどが入っている。 【変数・定数】 【変数の型】 ●教科書pp.26~27 ※数学と同様、コンピュータでも文字を使って数値や文字列を表すことができる。 これを『変数』と呼ぶ。 数学との大きな違いは、「文字列」を扱えることと、変数を使う前に『宣言』が 必要なことである。 変数の型には、以下のようなものがある。(●教科書 pp28~30, 46) データ型 データ型名 扱える内容 備考 バイト Byte 0~255 (2の8乗) 正の整数のみ 整数 Integer -32768~32767 (2の16乗) 整数のみ 長整数 Long 単精度 浮動小数点 Single ±3.4×1038~±1.4×10-45 倍精度 浮動小数点 Double ±3.4×10308~±1.4×10-324 文字列 String 文字列のみ 数字も文字列として扱う 万能 Variant 上記全て 『宣言』省略時はこの型 -2147483648~2147483647 (2の32乗) 整数のみ 【変数を用いた計算】 【変数への値の代入】 ①直接代入する a = 15 ※プログラムにおいて「=」は、 「右のものを左に代入せよ」の意 ②InputBox命令を用いる a = InputBox("aに値を入れる", "入力") ③セルから入力 次項にて説明 【変数を用いた計算】 a = 3 + 5 :aに3+5の計算結果(8)を代入 a = b + c :aにb+cの計算結果を代入 a = a + b :a+bを計算し、その結果をaに代入し直せ 【例題】Sub 足し算1() Dim a As Integer Dim b As Integer Dim c As Integer a = 10 b = 20 c = a + b MsgBox c End Sub a、b、cは整数型。 従ってこのプログラムでは小数は 使えないことに注意! aに10、bに20を代入 cにa+bの値(30)を代入 【演習】InputBox命令を使って数値を二つ入力させ、 それらの積を表示するプログラムを作成せよ。 課題 InputBox命令で入力した二つの数値をA1とA2に表示させ 積(A1×A2)をB1に、 差(A1-A2)をB2に、 B1、B2が負の数ならばC1、C2に「負の数」と 表示するプログラムを作成せよ。 なお、変数の宣言を確実に行い、コメントによる 補足説明を加えること。(要所だけでよい) また、言葉や条件にアレンジを加えても良い。 積(A1×A2) A 1 2 B 10 -5 C -50 負の数 15 B1が負の場合 B2が負の場合 差(A1-A2) InputBox命令で入力された値 なお、この解答例のような矢印等は必要ない
© Copyright 2025 ExpyDoc