エクセル顧客管理
顧客一覧のシートを作成

Excelマクロを駆使したカスタマイズ可能なエクセル顧客管理、エクセルVBAの学習教材
公開日:2013年5月以前 最終更新日:2014-11-11

第2回.顧客一覧のシートを作成


エクセルで顧客管理を作ります、


顧客管理でメインとなる、顧客一覧のシートを作成しましょう、


シート名は、「顧客一覧」で良いでしょう。


上2行と、左1列を空けて、セルB3から使い始めましょう。


上2行は、後にボタン等を付けて、いろいろ機能追加するときに使います。


左1行は見た目だけですが、とりあえず空けておきます。


では、セルB3から横に使用する項目を入力していきます。


B3~N3に

顧客番号

顧客区分

顧客名

顧客名カナ

郵便番号

住所

電話番号

携帯番号

URL

メール

担当者名

担当者携帯

担当メール


もっと多くの項目が必要になると思いますが、このシートで、いつでも追加・削除したものが、他のシートに反映するように作っていきますので、心配いりません。


ダウンこんな感じになると思います。

Excel VBA 解説
↑では、見出しに色を付け、罫線も100行分(103行まで)引きました。

ウインドウもE4で固定しています。

この行数も、いつでも増やせるので、とりあえずこの位でよいでしょう。


作成した項目の中で、「顧客区分」がちょっと分かりずらいと思います。


これは、顧客をグループ分けするために使用します。


ランク別にしたり、地域別にしたりと、いろいろ使い道があります。


ただし、その都度適当に入れてしまっては、グループ化できません。


そこで、「入力規則」の「リスト」を使用します。


「入力規則」の「リスト」を使用する前準備として、


このような項目名をリスト化する、専用のシート「項目名」を作成します。

そして、A列を顧客区分で使用しますので、


A1に、「顧客区分」と入力し、その下のA2から、実際の顧客区分を入力します。


ダウンこんな感じになると思います。

Excel VBA 解説
分かりやすく、ABCランクにしました。


ここまでは、問題ないですよね。



では、この顧客区分を使って、


シート「顧客一覧」の「顧客区分」に、「入力規則」の「リスト」を設定します。


名前定義

1.シート「項目名」を選択

2.Ctrl+F3を押して下さい。

  Ctrl+F3は名前定義の画面を表示するショートカットです。

  メニューからは、2003なら、「挿入」→「名前」→「定義」、

  2007以降なら、「数式」→「名前の管理」→「新規作成」

2.「名前」に、「顧客管理」と入力

3.2007以降の場合は、「範囲」は「ブック」のままにして下さい。

4.「参照範囲」に、「=OFFSET($A$2,0,0,COUNTA(項目名!$A:$A)-1,1)」と入力

5.「OK」


「入力規則」の「リスト」の設定

1.シート「顧客一覧」を選択

2.セルC4:C103までを選択。顧客区分の全範囲です。

3.2003なら、「データ」→「入力規則」、

  2007以降なら、「データ」→「データの入力規則」

4.「入力値の種類」で、「リスト」を選択」

5.「元の値」で、「顧客管理」と入力。F3で一覧から選択できます。

6.「OK」


これで、顧客区分にリストが設定されたはずです。


ここは説明が必要ですね。


まず、通常「リスト」で指定できるのは、同一シートだけです。

「入力規則」の「リスト」の設定の5.では、他シートは参照できません。

これを可能にするのが、名前定義です。

そして、シート「項目名」の追加・削除に自動的に対応させる為に、

「参照範囲」で、OFFSET関数を使用しています。

OFFSET(基準, 行数, 列数, 高さ, 幅)

基準のセルから指定の行数と列数だけシフトした位置にある、高さと幅のセル範囲を返す関数です。
COUNTA(範囲)

指定範囲の、空白でないセルの個数を返します。

-1は見出しがあるので、その分を引いています。


つまり、A2から0行0列シフト(同じA2)から、A列に入力された行数分の範囲になります。

これで、シート「項目名」の顧客区分への追加・削除に自動的に範囲が設定されます。


ついてこれていますか(笑)、次にいきますよ。



次は、「顧客名カナ」を自動で表示されるように、関数入れます。


セルE4で、「=PHONETIC(D4)」と入力して下さい。


PHONETIC(範囲)

ふりがなの文字列を取り出します。


セルE4をE103までコピーします。

コピーのテクニック(罫線を壊さずにコピーする方法)

E4をコピーし、E5:E103を選択後、「形式を選択して貼り付け」→「値」

または、E4のフィルハンドル(E4選択時の右下の小さい■)を、「Shift」を押しながらE103までドラッグ


少しは、それらしくなってきたと思います。


今回は、ここまで。



今日の復讐


名前定義

「入力規則」の「リスト」の設定
OFFSET(基準, 行数, 列数, 高さ, 幅)

COUNTA(範囲)PHONETIC(範囲)
PHONETIC(範囲)





同じテーマ「エクセル顧客管理」の記事

第1回.どんなソフトにするか

では、エクセルで顧客管理を作っていくわけですが、まずは、どんなソフトを作るのかを決めなければいけません、顧客管理は幅が広く、業種によっても様々です、まずは、ごく一般的なものを作成していきます。出来れば、「お客様第一」顧客管理システムに近い物ができれば良いと思います。
第2回.顧客一覧のシートを作成
第3回.顧客登録のシートを作成、その前にマクロって何?
エクセルで顧客管理を作ります、シート「顧客一覧」からシート「顧客登録」に項目名も含めて、自動で作成します、また逆に、シート「顧客登録」で入力したデータを、シート「顧客一覧」に登録します。これらは、関数ではできません。そこで、マクロの登場です。
第4回.顧客登録のシートを作成(1)
さて、いよいよマクロの作成に入ります、まずは、シート「顧客登録」を追加して下さい、中身は何も必要ありません、次に、「VisualBasicEditor」(VBEと略します、今後はVBEとだけ記述します)を起動して下さい。起動方法は前回説明しました。
第5回.顧客登録のシートを作成(2)
エクセルで顧客管理を作ります、前回の続きです、もう少し使えるマクロにします、前回までですと、「顧客区分」の「リスト」や書式が、「顧客一覧」からコピーされていません。これを追加して、前回までのマクロを再度。太字の部分が、追加した所です。
第6回.ここまでの復習
エクセルで顧客管理を作ります、ここまで、ハイペースで来ましたので、一旦整理しながら復習します、まず、エクセルのシートの確認です。シート「顧客一覧」シート「項目名」シート「顧客一覧」の「顧客区分」に、「入力規則」の「リスト」を設定します。名前定義 1.シート「項目名」を選択 2.Ctrl+F3を押して下さい。
第7回.本格的なプログラムへ
エクセルで顧客管理を作ります、前回までのプログラムは、説明の為のコーディングをした部分があります、本格的なプログラムを目指す為に、いろいろ手直ししようと思います。コーディングは好みの部分も大きいのですが、最も気を付けるべき事は、1.可読性 2.保守性 3.処理スピード になるかと思います。
第8回.顧客一覧より顧客データを取得
エクセルで顧客管理を作ります、これまでの感じはどうでしょうか、本当は、ここまでの全てが理解出来ていれば、もう自分でどんどんプログラムを作れてしまうと思います。つまり、全てが理解出来る人は、このブログを読んだりはしないと言う事です。と言う事は、全ては理解出来ていないからこそ、読まれているのですよね。
第9回.イベントを使ってマクロを起動させる
エクセルで顧客管理を作ります、前回までで、「顧客一覧」から、「顧客登録」のシートを作成し、「顧客登録」の「顧客番号」で、「顧客一覧」よりデータの取得まで出来ました。しかし、手動でマクロを起動したのでは、面倒ですよね。手っ取り早いのは、フォームコントロールのボタンを付けて、それにマクロを割り当てます。
第10回.コーディングとデバッグ
エクセルで顧客管理を作ります、前回までで、「顧客一覧」→「顧客登録」、が自動化出来ました、しかも、シート名も自由に変更できます。これだけでも、いろいろ応用範囲があり、結構使えるはずです。「何かの一覧」→「何かの登録」、として自由に使用が可能です。
第11回.顧客登録より顧客一覧へ更新
エクセルで顧客管理を作ります、プログラム完成へ向けて一気に突き進みましょう、今回は、「顧客登録」で入力した内容を、「顧客一覧」へ更新します。「顧客番号」が存在しない場合は、最終行の次へ、存在する場合は、その行へ更新します。その前に、まずSubモジュール「顧客一覧より取得」を少し修正します。


新着記事NEW ・・・新着記事一覧を見る

TRIMRANGE関数(セル範囲をトリム:端の空白セルを除外)|エクセル入門(2024-08-30)
正規表現関数(REGEXTEST,REGEXREPLACE,REGEXEXTRACT)|エクセル入門(2024-07-02)
エクセルが起動しない、Excelが立ち上がらない|エクセル雑感(2024-04-11)
ブール型(Boolean)のis変数・フラグについて|VBA技術解説(2024-04-05)
テキストの内容によって図形を削除する|VBA技術解説(2024-04-02)
ExcelマクロVBA入門目次|エクセルの神髄(2024-03-20)
VBA10大躓きポイント(初心者が躓きやすいポイント)|VBA技術解説(2024-03-05)
テンキーのスクリーンキーボード作成|ユーザーフォーム入門(2024-02-26)
無効な前方参照か、コンパイルされていない種類への参照です。|エクセル雑感(2024-02-17)
初級脱出10問パック|VBA練習問題(2024-01-24)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.RangeとCellsの使い方|VBA入門
6.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
7.セルのクリア(Clear,ClearContents)|VBA入門
8.メッセージボックス(MsgBox関数)|VBA入門
9.条件分岐(Select Case)|VBA入門
10.ブック・シートの選択(Select,Activate)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。


このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ