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

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

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

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

Q&A

解決済

2回答

2937閲覧

kaVBA 特定シートの抽出 別ブックへのコピー

songyong

総合スコア21

VBA

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

0グッド

0クリップ

投稿2018/10/06 11:30

編集2018/10/06 13:40

VBA初心者です。
お客さんによって、100程度あるシートの中から、特定のシートのみを抽出し、
お客さんの名前と有効期間をブック名として保存したいです。

以下のようなマクロを作成しました。

問題が2点あります。
➀指定しているワークシートが正しく出力されません、一枚のみ出ます。
⓶保存時の名前について
変数でbookNameを作成しているのですが、""でくくっているため、変数として認識されません。解決方法を具体的なコードで教えて頂きたいです。

以上、散文で申し訳ございません。
どうか、宜しくお願いします。

VBA

1Option Explicit 2 3Sub シート抽出() 4 5Dim clientName As String 6Dim period As String 7Dim bookName As String 8Dim val As Long 9Dim i As Integer 10Dim count As Long 11Dim copySheet As String 12Dim ary() As String 13 14clientName = Cells(13, 3).Value 15period = Cells(16, 3).Value 16count = Cells(19, 3) 17bookName = clientName & "_" & period 18val = 22 19i = 0 20 21ReDim ary(count - 1) 22 23For i = 0 To count - 1 24ary(i) = Cells(val, 3) 25val = val + 1 26Next 27 28Worksheets(ary(count - 1)).Copy Before:=Worksheets(2) 29 30ActiveWorkbook.SaveAs _ 31fileName:="C:\forClient\bookName", _ 32FileFormat:=xlOpenXMLWorkbook 33 34End Sub 35

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

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

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

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

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

guest

回答2

0

ベストアンサー

実際のセルのデータが提示されていないのでデバッグはしていませんが、コードを見る限りでの回答です。

①は複数のシートをまとめてコピーしたいのですから、配列の要素を指定したら意味がありません。
それと、新しいブックに保存したいのだと思いますが、「Before:=Worksheets(2)」が付いていると自ブック内でのコピーになってしまいますよ。
省略することで自動的に新規ブックにコピーされます。

VBA

1Worksheets(ary()).Copy

②は既に回答は出ていますが、ダブルクォーテーションから出すだけですね。

VBA

1ActiveWorkbook.SaveAs _ 2 fileName:="C:\forClient\" & bookName, _ 3 FileFormat:=xlOpenXMLWorkbook

ついでに、ブック名の.xlsxは省略しないほうが良いと思います。

VBA

1bookName = clientName & "_" & period & ".xlsx"

投稿2018/10/07 09:50

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

②にのみ回答します。
bookNameを変数として認識させる記載です。

ActiveWorkbook.SaveAs _ Filename:="C:\forClient\" & bookName, _ FileFormat:=xlOpenXMLWorkbook

投稿2018/10/06 18:17

TanakaHiroaki

総合スコア1063

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問