teratail header banner
teratail header banner
質問するログイン新規登録
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

1回答

2497閲覧

マクロを使った野球の成績データベースを作りたいです

satoA1996

総合スコア6

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2018/05/06 03:26

編集2018/05/06 10:19

0

0

エクセルのマクロ機能を使った野球の成績データベースを作りたいです

セルから選手名を拾ってその選手名のシートに選手の成績を日付けごと貼り付けていくマクロのプログラムを作りたいと思っています。

例)
5月6日の試合でA~D選手が出場しその成績をまとめたシート(図1)からA~Dの選手ごとに作られた年間の成績を日ごとにまとめるシート(図2)へコピーするマクロプログラムです

図1

図2

A選手の成績B2~K2をコピーしてA選手の名前のシートのC68~L68にコピーして貼り付ける形ですが、試合ごとに出場選手が変わるのでA列に入ってる名前からシート名を指定してその日の日付のところへコピーする形にしたいと思っています。

マクロ初心者なのでいろりろ調べて試していますが解決策がなかなか見つからないので、詳しい方是非どのようにすればできるか教えてください

追記(2018.05.06)
日付は入力欄を作るのでそこから引っ張る形にしたいです

選手ごとの成績は例えばAという選手ならAの選手の名前のシートでまとめる形にしたいです

”状況によりシート名や項目などの情報を変更するのはOKですか?図1と図2の関連性は何でしょうか?(別ファイル?同ファイル?)”
→同じブック内で処理をしたいです

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2018/05/06 09:33

タグに「VBA」を追加された方が良いように思います。また、質問編集画面のタイトル入力項目横にある初心者アイコンをご活用ください。
m.ts10806

2018/05/06 09:38

図1において「日付」はどのように分かるのでしょうか?図2において「選手名」はシート名が例えば「A」のようになっているという理解でよろしいでしょうか?
m.ts10806

2018/05/06 09:38

状況によりシート名や項目などの情報を変更するのはOKですか?図1と図2の関連性は何でしょうか?(別ファイル?同ファイル?)
mdj

2018/05/09 02:59

どこまでは出来ていて、どこからが出来ていないのか、がないと「やってほしいことだけ~」とされてしまいます。できているところまでを書いてもらえればと思います
guest

回答1

0

初心者さんということで、私なりの理解で処理手順の一例を示します

・準備

*試合成績シートの作成
1日に2試合あった場合は1試合ごとの表を下方向に並べて作成すると想定
つまり、Aさんが2試合にでていたら、Aさんの成績の行が2行ある
これは、選手別シートにある「試合数」が何であるかわからなかったので、きっと1日に2試合3試合ということもあるのだろうと推測したことによる

*選手名シートの作成
同姓同名に注意 → 名前を工夫する?最後に1、2、3、、、A,B,C、、、などを付加するとか

・処理手順
(1)処理する試合成績シートを表示してマクロを実行する
(2)(1)シートの2行目のA列:名前を拾う
(3)(2)で拾った名前のシートを処理対象にする(名前が無かったら警告!)
(4)(3)のシートでA列に試合日が既に入っているか行方向に探す(日付が無かったら警告!)
(5)(4)の行のB列:試合数に、空欄だったら1を入力、空欄でなければ+1する
(6)(1)シートの2行目のB列以降の成績を(4)のC列以降の同じ項目に対して加算する

以上で一人目が終了します

先ずはこの「一人目」がうまくいくまでがんばりましょう

一人できればあとは処理する行を変えて同じことの繰り返しです

(2)~(6)の処理を(1)シートの名前の入っている最終行まで繰り返します

以上ご参考まで

投稿2018/05/09 07:50

takito

総合スコア3116

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.30%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問