ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
事前準備: 開発タブを表示
Excel の標準状態では「開発」タブが隠れています。以下で表示します:
- ファイル → オプション
- リボンのユーザー設定
- 右側のリストで 開発 にチェック → OK
これで上部リボンに「開発」タブが追加され、ボタン・マクロ・VBE(Visual Basic Editor)にアクセスできるようになります。
方法1: フォームコントロールのボタン(推奨)
最も標準的で互換性も高い方法です:
- 開発タブ → 挿入 → フォームコントロール のボタン(一番左上のアイコン)をクリック
- シート上の任意の位置で ドラッグして矩形を描画
- マウスを離すと「マクロの登録」ダイアログが自動で開く
- 既存マクロを選ぶか、新規作成 → VBE が起動して空の Sub が生成される
- ボタンを右クリック → テキストの編集で表示名を変更
登録されるマクロの例:
' 標準モジュール (Module1)
Sub Button1_Click()
' クリック時の処理
Range("A1").Value = "Hello, VBA!"
MsgBox "ボタンがクリックされました"
End Sub
' セル A1〜A10 を黄色に塗る例
Sub HighlightCells()
Range("A1:A10").Interior.Color = RGB(255, 255, 0)
End Sub
' アクティブシートの値を別シートにコピー
Sub CopyToSheet2()
Sheets("Sheet1").Range("A1:C10").Copy _
Destination:=Sheets("Sheet2").Range("A1")
End Sub
方法2: ActiveX コントロールのボタン
イベントが豊富で、ボタン以外のプロパティ(色・フォント・画像)も細かく設定可能ですが、Mac 版 Excel では使えない点に注意:
- 開発 → 挿入 → ActiveX コントロール のコマンド ボタンを選ぶ
- シートにドラッグして配置(デザインモードが ON 状態)
- ボタンをダブルクリック → VBE が起動し、シートのコードペインに
Clickイベントが生成 - 編集後、デザインモードを OFF にしてからクリックすると動作
' Sheet1 のコードペイン(標準モジュールではない)
Private Sub CommandButton1_Click()
MsgBox "ActiveX ボタンがクリックされた"
End Sub
' マウスが乗った時
Private Sub CommandButton1_MouseMove(ByVal Button As Integer, _
ByVal Shift As Integer, ByVal X As Single, ByVal Y As Single)
CommandButton1.BackColor = RGB(200, 230, 255)
End Sub
' キー押下
Private Sub CommandButton1_KeyDown(ByVal KeyCode As MSForms.ReturnInteger, _
ByVal Shift As Integer)
If KeyCode = vbKeyReturn Then
Call CommandButton1_Click
End If
End Sub
方法3: 図形や画像にマクロを割り当てる
見た目を自由にしたい場合は図形ボタンが便利:
- 挿入 → 図形 から好きな図形を配置
- 図形を選んで右クリック → マクロの登録
- マクロを選択 → OK
VBA から動的に割り当てる場合:
Sub AssignMacroToShape()
Dim sh As Shape
Set sh = ActiveSheet.Shapes.AddShape( _
Type:=msoShapeRoundedRectangle, _
Left:=100, Top:=100, Width:=120, Height:=40)
sh.TextFrame2.TextRange.Text = "実行"
sh.OnAction = "Module1.RunMyMacro" ' クリック時に呼ぶマクロ名
sh.Name = "BtnRun"
End Sub
Sub RunMyMacro()
MsgBox "図形ボタンから実行されました"
End Sub
' ボタン削除
Sub DeleteButton()
On Error Resume Next
ActiveSheet.Shapes("BtnRun").Delete
End Sub
フォームコントロール vs ActiveX の比較
| 項目 | フォームコントロール | ActiveX |
|---|---|---|
| 互換性 | ◎ (Mac, Web 含む) | × (Windows のみ) |
| イベント | Click のみ | Click / MouseMove / KeyDown など多数 |
| 外観カスタマイズ | 制限あり | 自由(色・フォント・画像) |
| VBA からのアクセス | シェイプ経由 | オブジェクトとして直接 |
| セキュリティ警告 | 少ない | マクロ警告が出やすい |
実用例: ボタンでフォーム化された処理
' データ入力 → ボタンで台帳追加 → クリアの一連動作
Sub AddRecord()
Dim ws As Worksheet
Dim lastRow As Long
Set ws = Sheets("台帳")
lastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row + 1
With Sheets("入力")
ws.Cells(lastRow, "A").Value = .Range("B2").Value ' 名前
ws.Cells(lastRow, "B").Value = .Range("B3").Value ' 年齢
ws.Cells(lastRow, "C").Value = Now ' 登録日時
End With
Call ClearForm
MsgBox "登録しました (行 " & lastRow & ")"
End Sub
Sub ClearForm()
Sheets("入力").Range("B2:B3").ClearContents
Sheets("入力").Range("B2").Select
End Sub
FAQ
Q: ボタンを押しても反応しない
A: マクロ警告でブロックされている可能性。ファイル → 情報 → コンテンツの有効化。または信頼できる場所にファイルを置く(Excel オプション → セキュリティ センター → 信頼できる場所)。
Q: ActiveX ボタンが「オブジェクトを挿入できません」エラー
A: 既知の Windows Update 不具合。レジストリの HKCU\Software\Microsoft\Office\\Common\\COM Compatibility 配下の MS Forms 関連エントリ削除、または *.exd ファイル(%TEMP%\\Excel8.0\\)削除で復旧することが多い。
Q: ボタンが選択できない
A: フォームコントロールは Ctrl + クリックまたは右クリックで選択。ActiveX は デザインモードを ON にすると編集可能。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?