質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.35%
VBA

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

Q&A

解決済

2回答

1287閲覧

【VBA】選択セルの結合 行で複数セル一括同じ処理

sh444

総合スコア15

VBA

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

0グッド

0クリップ

投稿2021/09/09 03:32

VBAで行いたいことは、下記の手順です。

①セル内で選択した範囲をセルの結合する。(選択するセルは行だけです)
②結合した左上のセルを取得して、各決まった複数列の該当セルを結合する。(この際に、①で選択行の個数に併せて結合します)

②での残りのセルの結合する列は決まっており、①での選択範囲次第で行の個数が変わるだけです。

例えば、B2:B5まで選択します。そのあとC2:C5・G2:G5、H2:H5も結合という流れです。C,G,Hは決まっています。

そこで、下記のコードを作ったのですが、「繰り返し処理」内のコードだとセルが決まっていますが、決まっていない場合の処理の繰り返し方法がわかりません。

ヒントをいただけないでしょうか。

Sub

1 2'選択範囲の結合 3Selection.Merge 4 5'選択セルの取得 6Dim l As Long 7l = Selection.Row 8l = Selection.Column 9 10Dim s As String 11s = Selection.Address 12 13'残りのセルの選択 14 15 16'繰り返し処理 17Union(Range(Cells(1, "A"), Cells(4, "C")), Range(Cells(6, "E"), Cells(10, "G"))).Select 18 19End Sub 20コード

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

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

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

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

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

guest

回答2

0

解決済みですが、ご参考までに。

vba

1Sub MergeSample() 2 Dim Sel As Range 3 Set Sel = Selection 4 Sel.Merge 5 6 Dim r As Range 7 For Each r In Intersect(Sel.EntireRow, Range("G:G,H:H,J:J")).Columns 8 r.Merge 9 Next 10End Sub

投稿2021/09/09 04:32

hatena19

総合スコア34075

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

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

0

ベストアンサー

こんな感じでしょうか?

VBA

1Sub MergeSample() 2 Dim Origin As Range 3 Set Origin = Selection 4 5 Dim vAddress As String 6 vAddress = Origin.Address(True, False) 7 Dim StartRow As Long 8 Dim EndRow As Long 9 10 StartRow = Split(Split(vAddress, ":")(0), "$")(1) 11 EndRow = Split(Split(vAddress, ":")(1), "$")(1) 12 13 Dim Target As Variant 14 Target = Array("G", "H", "J") 15 16 Dim i As Long 17 For i = LBound(Target) To UBound(Target) 18 Range(Target(i) & StartRow & ":" & Target(i) & EndRow).Merge 19 Next 20End Sub

投稿2021/09/09 03:43

編集2021/09/09 03:53
hex309

総合スコア761

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

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

sh444

2021/09/09 03:47

ありがとうございます!! 選択したセルの結合も追加でコードを加えたのですが、エラーにならずに利用できました^^ お手数おかけいたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問