excelで、ミニテストを作っているのですが、いままで作ったものをランダムでえらんだまとめテストを作ろうと思っています。毎回、手動で選んでいるのですが、何種類も作るのが大変なので、Excelで自動に作る方法を教えてください。
現在の形式は
l l テスト第1回 l なまえ l
l 01 l 漢字 l 答え l
l 02 l 漢字 l 答え l
・
・
・
l 25 l 漢字 l 答え l
l l テスト第2回 l なまえ l
l 26 l 漢字 l 答え l
l 27 l 漢字 l 答え l
このように25個ずつテストを用意しています。
まとめテストはテスト第1回~第5回の中から25個選んで、別のシートに
l l テスト第1~5回 l なまえ l
l 05 l 漢字 l 答え l
l 29 l 漢字 l 答え l
l 34 l 漢字 l 答え l
l 36 l 漢字 l 答え l
のように選択した範囲内のものを25個出力できるようにしたいと思っています。
よろしくお願いします。
A 回答 (5件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
#02です。
一番簡単そうな方法で説明します。過去の問題が登録されているBOOKを開いて、ツール→マクロ→新しいマクロの記録 を選びます。「マクロの記録」といウィンドウはそのままOKでよいです。
次にツール→マクロ→記録終了 を選びます。これで(見えませんが)標準モジュールシートが作成されました。次にそのシートを表示させます。そのためには Alt+F11 を押下します。
すると 「Sub Macro1() ・・以下省略」のような、今記録したマクロが表示されているはずです。この1行目のSub Macro1()の上に#02のマクロ全文をペーストしてください。(Option Explicitが先頭行になるように)
元の問題文のシートに戻り、シート名を”過去問”に変更して、Alt+f8 を押下すると、実行可能なマクロのリストが表示されますから、その中から”問題作成”を選んで「実行」ボタンをクリックしてみてください。
なお#02のマクロは夜中に急いで作ったので、美しくありません(→言い訳です)
A列の番号は途中の行が空白でも良いですが、最小値は1で抜け番がないことが前提となっていますのでお気をつけください。抜け番があると
k = Application.Match(NO(l - 1), Worksheets("過去問").Range("A1:A2000"), 0)
の行でエラーとなる場合があります。
過去問(第6回以降)を行の末尾に追加してもマクロは動作するはずです。
この回答への補足
おっしゃる通りにやってみたところ
IntRND = Int((Rnd(Now()) * 1062347) Mod NumMAX) + 1
の行でエラーが出たみたいです。
どうしたらいいでしょうか?
No.2
- 回答日時:
過去問のシート名を”過去問”とします。
またA列は重複のない数字としますその前提で以下のマクロを実行してみてください
Option Explicit
Sub 問題作成()
Dim i, j, k, l, NumMAX, IntRND As Integer
Dim NO(25)
Dim SHname As Worksheet
i = 0
IntRND = Rnd(0)
NumMAX = Application.Max(Worksheets("過去問").Range("A:A"))
For Each SHname In Worksheets
If SHname.Name = "新問題" Then
i = 1
End If
Next
If i = 0 Then
Worksheets.Add.Name = "新問題"
Else
Worksheets("新問題").Range("a1:C100").ClearContents
End If
Worksheets("新問題").Range("B1") = "問題1~5"
Worksheets("新問題").Range("C1") = "なまえ"
NO(1) = 0
j = 1
Do
IntRND = Int((Rnd(Now()) * 1062347) Mod NumMAX) + 1
For i = 1 To j
If NO(i) = IntRND Then
i = 9999
End If
Next i
If i < 9999 Then
NO(j) = IntRND
j = j + 1
End If
Loop Until j > 25
For l = 2 To 26
Worksheets("新問題").Cells(l, 1) = NO(l - 1)
k = Application.Match(NO(l - 1), Worksheets("過去問").Range("A1:A2000"), 0)
Worksheets("新問題").Cells(l, 2) = Worksheets("過去問").Cells(k, 2)
Worksheets("新問題").Cells(l, 3) = Worksheets("過去問").Cells(k, 3)
Next
End Sub
この回答への補足
すみません。Excelはほとんど素人なので、マクロとかが良く分かりません。詳しく分かるサイトまたはその方法を教えていただけないでしょうか?
補足日時:2006/06/13 14:03No.1
- 回答日時:
どこか1列を使います。
そこに
=RAND()
と入れて、問題の行数分コピーします。
このRANDという関数は、再計算([F9]キー)する度に毎回違った数(乱数)を出力するものです。
再計算した後、この関数を入れた列で並び替え([データ]→[並べ替え])をすれば、順序がランダムで並び変わります。
並べ替えの結果、上位25問を、まとめテストにするというのはいかがでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- 簿記検定・漢字検定・秘書検定 正答率の出し方について 1 2023/01/04 17:15
- その他(悩み相談・人生相談) 自分の頭が悪すぎて恥ずかしいですごめんなさい。 なるべく多くの人に答えてもらえたら嬉しいです。 小学 6 2022/03/28 03:17
- その他(教育・科学・学問) 国語の先生に言われました。 (文法とか漢字じゃないです) 国語には答えが存在しないんだよ。 作者がど 16 2022/07/29 11:21
- 中学校 間違った国語の実力テストの勉強? 1 2022/08/28 15:59
- 日本語 漢字の書きについてです。 けっこう前のテストを見直していたら、 「チョウテンがダメでも私が慰めてあげ 1 2022/04/11 20:32
- 日本語 読めない漢字や、変感できない漢字、読めるけど書けない漢字を別の代用するのはダメなんですか? 私はよん 7 2023/05/28 12:15
- その他(法律) 昭和の役所に登録出来る氏名について 2 2022/08/17 23:31
- 会社・職場 20歳の社会人です。悩みがあります。私はとても漢字が苦手です。それは小さい頃からなのですがパッと言わ 5 2022/03/25 10:15
- 日本語 中国語と日本語とでは、どちらが先に漢字を廃止するでしょうか? 2 2023/01/29 13:45
- 子育て 小5の娘(知能低め)のNintendo Switchについて 今日娘が漢字テストがあるから漢字の勉強 6 2023/07/05 20:52
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelで数字を入れたら対応する...
-
エクセルで複数のシートのクリ...
-
Excel VBAでのWorksheet_Change...
-
Excelのシート上のShapeにイベ...
-
【エクセル】フリーワード検索...
-
excelのマクロが上手く動作しま...
-
エクセルファイルを開いた回数...
-
長い時間かかるマクロが実行中...
-
EXCELのダイアログシートって、...
-
エクセル シート内の一番下のセ...
-
マクロ1があります。 A1のセル...
-
エクセルで特定の行だけ行削除...
-
【エクセル】「実行時エラー’10...
-
シート全体の絶対参照
-
エクセルのチェックボックス誤作動
-
エクセル:セル内の文字列の最...
-
Excelでセル内の文字をファイル...
-
エクセルのマクロ実行後にカー...
-
セルの一部分だけを太字にする方法
-
「マクロが含まれているファイ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel VBAでのWorksheet_Change...
-
エクセルで複数のシートのクリ...
-
Excelで数字を入れたら対応する...
-
エクセル シート内の一番下のセ...
-
エクセルファイルを開いた回数...
-
Excelのシート上のShapeにイベ...
-
Excelでセル内の文字をファイル...
-
【エクセル】「実行時エラー’10...
-
長い時間かかるマクロが実行中...
-
エクセルで特定の行だけ行削除...
-
セルの一部分だけを太字にする方法
-
EXCELのダイアログシートって、...
-
エクセル:セル内の文字列の最...
-
マクロ1があります。 A1のセル...
-
Excelにて、同じ画像を複数のセ...
-
エクセルで○をつけるマクロ設定
-
【エクセル】フリーワード検索...
-
エクセルVBAで内容変更のたびに...
-
前月分を次月シートに繰越でき...
-
excel定数の違いについて。xlAu...
おすすめ情報