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

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

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

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

Q&A

解決済

1回答

353閲覧

シート名をコピーした際に、参照シートを自動で変更する

Yukidarumannnnn

総合スコア30

VBA

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

0グッド

0クリップ

投稿2022/07/05 01:01

前日分のシート名を自動で入れたい

Excel日計処理で前日分の集計と本日の集計を加算して、収入累計を計算しています。
VBAで翌日分のシートを作っているのですが、毎回手動で参照するシート名を変更しているのを自動で変更したく思います。

例)
シート0708の収入累計には('0707!AD17+T17)というように前日シート名を自動で式に入れたい。

イメージ説明

翌日のシート名は以下のVBAを設定してシートをコピーして使っています。

翌日のシート作成

Sub 月次更新() 'バックグラウンドで作動 Application.ScreenUpdating = False 'シート名用の変数定義 Dim D As String 'シート名を翌日分の数字4桁にする D = Format(Date + 1, "MMDD") '右端のシートをコピーして新しいシートを一番右に配置 Worksheets(Worksheets.Count).Copy after:=Worksheets(Worksheets.Count) '新シートにさっき決めた名前をつける ActiveSheet.Name = D End Sub

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんな感じでどうでしょうか。

'数式を置換 Dim B As String, A As String B = Format(Date - 1, "'MMDD'") A = Format(Date, "'MMDD'") Dim c As Range For Each c In ActiveSheet.Cells.SpecialCells(xlCellTypeFormulas) c.Formula = Replace(c.Formula, B, A) Next

投稿2022/07/05 01:44

jinoji

総合スコア4585

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

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

Yukidarumannnnn

2022/07/05 08:32

有難うございます。 シートをコピーした後に For Each構文入れる感じでしょうか。 試してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問