
No.3ベストアンサー
- 回答日時:
エクセルのバージョンによるかもしれないのでよろしく。
下記は、参考にしてください。
VBなどと、またコントロールツールボックスのそれと、フォームのコントロールは不統一で難しいところと思う。
ーー
私はいつも確かめながら手探りで
Sub test02()
MsgBox Worksheets("Sheet3").Shapes(1).Name
End Sub
を実行する。Nameは強力で、エラーはまず出ない。
Button 1(半角スペースに半角1と思うが)が判る。
ーー
これを直接使わないで(半角やスペースの問題で)
n = Worksheets("Sheet3").Shapes(1).Name
のように文字列nに入れて
ーー
Sub test03()
n = Worksheets("Sheet3").Shapes(1).Name
Worksheets("Sheet3").Shapes(n).Select
MsgBox Selection.Caption
End Sub
を実行して、現在のCaptionが出ることを確かめかめて
(Captionも最近のVBなどで、Textなんかに変わったりしているので怖い)
ーー
Sub test04()
n = Worksheets("Sheet3").Shapes(1).Name
Worksheets("Sheet3").Shapes(n).Select
Selection.Caption = "実行ボタン"
End Sub
で実行ボタンに変わったことを確かめた。
ただマクロの記録と違ったカタチでできた。
ーー
色を設定(質問には無いが)
Sub test04()
n = Worksheets("Sheet3").Shapes(1).Name
Worksheets("Sheet3").Shapes(n).Select
Selection.Caption = "実行ボタン"
Selection.Font.ColorIndex = 5
End Sub
これもマクロの記録と違うができた。
エクセルのフォームのコントロールのプロパティは、手に負えない。
詳しい説明ありがとうございました。マクロの記録などで確かめながらマクロを組んでいますが、同じように研究されている方が多いようで、安心しました。今回は、select selectionを省きたかったのですが、そうは行かなかったようです。
No.2
- 回答日時:
新しいマクロの記録を用いて、シート上のボタンのテキストを変更すると下記のようなマクロが生成されます
Sub Macro2()
ActiveSheet.Shapes("Button 1").Select
Selection.Characters.Text = "ボタン 3"
End Sub
実際のシート上に何個のボタンがあって、どのようにされたいのか分かりませんが参考にはなると思います。
ボタンが複数あるなら例えば以下のようなマクロでもできます
Sub Macro3()
Dim idx As Integer
For idx = 1 To ActiveSheet.Shapes.Count
If Left(ActiveSheet.Shapes(idx).Name, 6) = "Button" Then
ActiveSheet.Shapes(idx).Select
Selection.Characters.Text = "Button " & idx
End If
Next
End Sub
ありがとうございました。shapes()のインデックスが分からなかったのと、.Select Selection.を省きたかったのですが、そうは行かないようですね。
No.1
- 回答日時:
マクロの記録で調べられると思います。
ActiveSheet.Shapes("Shapeの名前").Select
Selection.Characters.Text = "新しいテキスト"
↑文字だけ変えるならこんな感じ。
早速ありがとうございます。私もマクロの記録で作ってみましたが、
ActiveSheet.Shapes("Shapeの名前").Characters.Text = "新しいテキスト" というようにしたかったのですが、うまく行きませんでした。
選択した後で、選択を解除するしかないようですね。シートに保護をかけると、ボタンの選択もできなくなります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
VBA シートのボタン名を変更したい
Visual Basic(VBA)
-
Excel VBAで、実行時にsheet上のコマンドボタンのCaptionを変更する。
Excel(エクセル)
-
Excelマクロでオプションボタンの名前の変更をしたい
Excel(エクセル)
-
-
4
エクセルのマクロボタンが編集できません
Excel(エクセル)
-
5
Excel VBA ワークシートに貼られたボタン名(Caption)をセルの値から取得するには
その他(プログラミング・Web制作)
-
6
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
7
VBA(エクセル)で自動的にボタンをクリックさせるには
その他(プログラミング・Web制作)
-
8
CommandButtonのCaptionを変化させたい
Visual Basic(VBA)
-
9
エクセル・VBA CheckBoxのオブジェクト名に変数を使うことは可能でしょうか?
Excel(エクセル)
-
10
オブジェクト(コントロール)の名前を変更したい
Excel(エクセル)
-
11
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
12
【Excel VBA】マクロでExcel自体を終了させたい
Excel(エクセル)
-
13
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
14
初歩的な事だと思います。 Sub または Function が定義されていません。
Visual Basic(VBA)
-
15
Excel VBAでのWorksheet_Changeが動作しない原因
Excel(エクセル)
-
16
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
17
コマンドボタンやイメージにマウスをのせるとボタン名を表示したい
Excel(エクセル)
-
18
VBA:結合されたセルに対する「Target」について
Access(アクセス)
-
19
ExcelのVBAのマクロで他のシートの複数項目をクリアする方法
Visual Basic(VBA)
-
20
マクロボタンを押すたびに違う動作をしたい
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
LibreOffice Clalc(またはエク...
-
【マクロ】excelファイルを開く...
-
【関数】3つのセルの中で最新...
-
【マクロ】数式を入力したい。...
-
Office2021のエクセルで米国株...
-
エクセルのリストについて
-
【マクロ】【相談】Excelブック...
-
【マクロ】元データと同じお客...
-
【画像あり】オートフィルター...
-
エクセルの関数について
-
【マクロ】左のブックと右のブ...
-
他のシートの検索
-
【マクロ】実行時エラー '424':...
-
エクセルのVBAで集計をしたい
-
vba テキストボックスとリフト...
-
【マクロ】【配列】3つのシー...
-
【関数】=EXACT(a1,b1) a1とb1...
-
【マクロ画像あり】❶1つの条件...
-
エクセルの複雑なシフト表から...
-
【マクロ】変数に入れるコード...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
別シートのマクロを実行する方法
-
Application.Runエラー(1004)
-
エクセルのマクロボタンが編集...
-
Access終了時にマクロまたはVBA...
-
エクセルVBAで、ボタンの文字を...
-
private sub にしたらマクロが...
-
access2010 コマンドまたはアク...
-
シート保護を掛けたまま並べ替...
-
マクロとモジュールの違いを教...
-
アクセスのマクロについて
-
エクセルのマクロ
-
InputBox内の表示について
-
エクセル VBA SendKeys ループ...
-
マクロ 戻るボタンを押したらシ...
-
特定のシートだけ印刷はマクロ...
-
マクロが登録できません
-
ExcelのVBAでDisplayalertsで警...
-
excelで会議室予約表の作成(マ...
-
Excel起動時に画面表示縮小を自...
-
Excel2002を閉じるときの個人用...
おすすめ情報