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

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

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

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

Q&A

解決済

2回答

554閲覧

Sheetのcopyで新たなBookを作る場合の新たなBookとSheetを扱う方法について

xail2222

総合スコア1506

VBA

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

0グッド

0クリップ

投稿2021/04/19 14:06

前提・実現したいこと

Sheetのcopyで新たなBookを作る場合、copyメソッドには戻り値がないため
新たなBookやSheetを取得するための良い手法を知りたいです。

こんな手法があるとか
試したことの例示の内容の認識が間違っているとか
これで十分です等の情報があれば教えてください。
よろしくお願いします。

試したこと

tSheetがコピーする対象のシートだとした場合…

(1)

VBA

1 tSheet.Copy 2 Dim tToBook As Workbook 3 Dim tToSheet As Worksheet 4 Set tToBook = ActiveWorkbook 5 Set tToSheet =tToBook.Sheets.Item(1)

等のようにActive何とかを使ってBookとSheetを取得する方法が
最もシンプルだと思いますが「ActiveWorkbook」とか
対象が不明瞭なコードは如何なものか。と思っています。
※私は大抵…これで実装してますが。

(2)

VBA

1 Dim tCol As Collection 2 Set tCol = New Collection 3 4 Dim tToBook As Workbook 5 Dim tToSheet As Worksheet 6 7 Set tToBook = Workbooks.Add 8 For Each tToSheet In tToBook.Sheets 9 tCol.Add tToSheet 10 Next 11 Set tToSheet = tToBook.Sheets.Item(1) 12 tSheet.Copy after:=tToSheet 13 For Each tToSheet In tCol 14 tToSheet.Delete 15 Next 16 Set tToSheet = tToBook.Sheets.Item(1) 17 tToSheet.Name = tSheet.Name

Bookを予め作っておいて、そこにシートをコピーし
余計なのを後で削除するという手順です。
「tToBook.Sheets.Item(1)」という所が不明瞭な感じがしますが
1シートのみ残っている状態であれば確定されるので許容かと思います。
そういう意味では、tToBook.ActiveSheetでもいいと思います。
ただ大層です。こんなのならしない方が良いのではと思ったりします。

(3)

VBA

1 tSheet.Copy 2 Dim tToBook As Workbook 3 Dim tToSheet As Worksheet 4 Set tToBook = Workbooks(Workbooks.Count) 5 Set tToSheet = tToBook.Sheets.Item(1)

最後に追加されたBookだからWorkbooks(Workbooks.Count)で取れる
らしいですが、なんだか不安です。
※似たような実装の仕方をしたこともありますが。

補足情報(FW/ツールのバージョンなど)

Windows10
Excel2016,365

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

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

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

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

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

guest

回答2

0

(1)か(3)でいいのではないかな。
下記のページでもおなじことをしてますね。

Worksheet.Copyで新規に作成されたブック名の取得:エクセルマクロ・Excel VBAの使い方/Workbookオブジェクト

投稿2021/04/19 16:32

hatena19

総合スコア34053

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

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

xail2222

2021/04/19 20:53 編集

回答ありがとうございます やはり、1か3ですか。私は2も良いかなとか思ったりするときもあったのですが迷走しているだけかもしれないですね。 実装もしそうな勢いでしたが、やめることにします。理念次第で、2もありかなと思ったりしたのとネットに書いてるひともいた。と思って今再度見直したら、悪い例?のような感じで書かれてました。 http://officetanaka.net/excel/vba/tips/tips170.htm まあ人それぞれ理念があるから色々な実装があると思うので2も否定はすべきじゃないと思ったりもするのですが、処理時間はかかるし可読性もないので良くない実装という所までいくでしょうか。
guest

0

ベストアンサー

私も同じことで悩んでいましたが、実用上問題ないので(1)の方法を使っています。

ほかに思い当たる方法としては
1.新規シートを作成
2.数式貼り付け
3.書式貼り付け
でいけるかもしれません。狭い範囲のコピーを手作業でやる時はこの方法でよくやります。
これを全セルに適用すればいいと思いますが処理に時間がかかるかもしれません。

投稿2021/04/19 15:37

vann_2921

総合スコア190

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

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

xail2222

2021/04/19 20:53 編集

回答ありがとうございます。 やはり、悩みますよね。同じ事で悩んだ経験のある人がいて安心しました。1で正常動作しなくなるのはデバッグ時に処理を止めてactiveなのを変えた時位でしょうか。なので実用上は問題無いといえますよね 張り付けの例の提示もありがとうございます。クリップボードを使ってと言う事だと思いますが、クリップボードも処理時にパソコン操作次第で正常動作しなくなるので可能なら避けるべきかなと思ったりしますが、どうしても使う場合があるのでその使用量次第で運用制限をかけてもらうようにしています
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問