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

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

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

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

マクロ

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

Q&A

解決済

2回答

276閲覧

下の表だけ罫線を引く

ichigo15

総合スコア14

VBA

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

マクロ

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

0グッド

0クリップ

投稿2020/05/14 07:23

前提・実現したいこと

上下 2つ並んだ表に罫線を引きます。

上の表の行と列は流動的で、A2~
下の表は上の表の列と始まりも終わりも一緒です。

発生している問題

下の表の罫線の引き方が難しくて困ってます。

Dim e As Range Dim f As Range  Set e = Cells(3, Columns.Count).End(xlToLeft) Set f = Cells(Rows.Count, "A").End(xlUp).Offset(-3) Range(f, e).CurrentRegion.Borders.LineStyle = True

試したこと

範囲指定をRange("A"&f, "A"&e)と変更してみましたがだめでした。
ご指導よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

自己解決

セル番地ではなく、行数、列数で作り直してみましたら希望通りに
罫線が引けるようになりました。

皆様ありがとうございました。

Dim r As Integer Dim c As Integer r = Cells(Rows.Count, 1).End(xlUp).Row c = Cells(3, Columns.Count).End(xlToLeft).Column Range(Cells(r - 2, 1), Cells(r, c)).Borders.LineStyle = True End Sub

投稿2020/05/15 03:27

ichigo15

総合スコア14

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

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

0

上の表の行と列は流動的とされていますが、3行目には確実にデータがあるのでしょうか?
であれば上の表は3行目の最終セルを基準に、下の表は上の表の最終列の最終行を基準にCurrentRegionで線を引けばいいのでは?

VBA

1Dim maxCol As Long 2maxCol = Cells(3, Columns.Count).End(xlToLeft).Column 3Cells(3, maxCol).CurrentRegion.Borders.LineStyle = True 4Dim maxRow As Long 5maxRow = Cells(Rows.Count, maxCol).End(xlUp).Row 6Cells(maxRow, maxcol).CurrentRegion.Borders.LineStyle = True

投稿2020/05/14 13:35

ryuno_vanilla

総合スコア119

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

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

ichigo15

2020/05/15 01:41

コメントありがとうございます。 ご提示下さったコードは上の表に罫線を引くものでしょうか。 申し訳ございませんが下の表に罫線を引くのに苦戦しております。 上の表については問題ありません。 それと、上の表の最終列の最終行が空白セルだった場合どうしたらよろしいのでしょうか? 教えて頂けますでしょうか。 よろしくお願いいたします。
ryuno_vanilla

2020/05/15 03:27

上の表と下の表の間に空白行があると想像して上のコードを書きました。 上記コードは上の表、下の表の順で罫線を引いています。 上の表→3行目の最終列のCurrentRegion 下の表は上の表と列が同じことから 上の表の最終列の(シートの)最終行が下の表のセルになりませんか?? 下の表の罫線を引くコード Cells(maxRow, maxcol).CurrentRegion.Borders.LineStyle = True でした。 >最終列の最終行が空白 値が入っているセルが最終行なので問題ないです。 これでできないのであればどんな表なのか図で示してくださいますか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問