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

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

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

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

Q&A

2回答

2498閲覧

VBA シート番号 右からの数え方

Yoshikun_0945

総合スコア224

VBA

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

0グッド

0クリップ

投稿2018/03/17 05:42

編集2018/03/17 06:28

VBAで、アクティブブックのシート数(シートの順番)を右から左の方向で数える方法はございますか?

Worksheets(i)と記述すると左からi番目のシート(位置)という意味ですが、これを右から数えてi番目のシートとして記述したい場合はどうすればよろしいでしょうか

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

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

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

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

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

guest

回答2

0

Worksheets.Countでワークシート数が求められますから、端的に記述すると、
Worksheets(Worksheets.Count -i -1)
となります。

投稿2018/03/17 06:59

編集2018/03/17 07:02
sazi

総合スコア25173

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

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

0

おそらく質問者さんがやりたいのは「数える」ではなく「列挙する」ことだろうと思います。数えるのに右も左も関係ないと思いますし、Countプロパティーを見れば数を数える必要はありません。

Worksheetは名前ではなく位置でも参照できます。それゆえ左から右へ参照したい場合は位置として1から順番にNまで参照すればよいですし、逆順にしたければNから1まで順に参照すればよいです。

Sub foo() Set bk = ActiveWorkbook n = bk.Worksheets.Count For i = n To 1 Step -1 ActiveSheet.Cells(i, 1) = bk.Sheets(i).Name Next End Sub

投稿2018/03/17 05:58

KSwordOfHaste

総合スコア18394

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問