VBAで1つのシートを保存する方法やブックを保存するはわかるのですが
「不要なシートを除いて、他全てのシートをひとつのブックとして保存」する方法がわかりません。
わかる方教えてください。
▼作業の流れ▼
【1】操作するシートである計算を行います。
※現在のシートは1つとします。
「操作」シート
【2】計算結果はシートが追加され各シートに移動されます。
(1)シート、(2)シート・・・と(最大は20まで)
【3】各シートに割り振られたら(「操作」シートを除いて)名前をつけて保存します。
※現在のシートは4つあるとします。
「操作」シート 「(1)」シート 「(2)」シート 「(3)」シート
(1)、(2)、(3)の3つシートだけを「名前を付けて保存」をしたいと考えています。
No.3ベストアンサー
- 回答日時:
「操作」シート の位置が特定できなかったので面倒な書き方になりましたが、「操作」という名前のシート以外を別名保存させる一例です。
Sub test01()
Worksheets(Worksheets.Count).Select
If ActiveSheet.Name = "操作" Then
Worksheets(Worksheets.Count - 1).Select
End If
For Each ws In ThisWorkbook.Worksheets
If ws.Name <> "操作" Then
ws.Select (False)
End If
Next
ActiveWindow.SelectedSheets.Copy
Application.Dialogs(xlDialogSaveAs).Show
End Sub
No.4
- 回答日時:
こんにちは。
こんなかんじでどうですか?
Sub test1()
chk = 0
With ThisWorkbook
OWN = .Name
If .Worksheets.Count <> 1 Then
For Each ws In .Worksheets
If ws.Name <> "操作" Then
ws.Select (False)
chk = 1
End If
Next
If chk = 1 Then
ActiveWindow.SelectedSheets.Copy
NWBN = Application.Dialogs(xlDialogSaveAs).Show
If NWBN = True Then
ActiveWorkbook.Close False
Workbooks(OWN).Activate
Application.DisplayAlerts = False
ActiveWindow.SelectedSheets.Delete
Application.DisplayAlerts = True
End If
End If
End If
End With
End Sub
ご回答有難うございます。
上記のプログラムですと、「ブックのシートをすべて削除または非表示にすることはできません。」とエラーが出てしまいましたが大変参考になりました。どうも有難うございました。
No.2
- 回答日時:
次の手順で実行すればどうですか。
・現在のブックを上書き保存する。
・保存したブックのファイル名を変更する(NAMEコマンド)。
・変更したブックを読み込む。
・不要シートを削除する。
・ブックを保存して閉じる。
こうすれば、マクロを実行しているブックとシートを削除するブックは違いますから止まることはないと思います。
回答有難うございます。
上記手順を見て、なるほどーと思いました。
※確かに私が見た複数保存機能は上記のような手順で動いていた感じでした。
(別のブックが一瞬表示させる謎がわかりました。)
複数保存のカラクリはこういう風になっているんですね
大変参考になりました。
No.1
- 回答日時:
「操作」シートを削除してから、ブックを「名前を付けて保存」で新規のブックに保存すればよい。
この回答への補足
ご回答有難うございます。
上記の方法は自分も考えてみたのですが、「操作」シートを削除するとプログラムが動作しなくなってしまうのでボツにしています。
他のシートで動かすという手もありますが「操作」シートを削除されて「保存」をキャンセルした場合「操作」シートが消えているマズイので他の方法を探しています。
偶にVBAで特定のシートを複数 保存するのを見かけますが、操作を行う不要なシートは削除しているんでしょうかね?
※正常に保存されたら、ちゃんと元の状態になっています。(削除した気配がありません)
どのようなカラクリで保存しているのか全くわかりません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
あるあるbotに投稿したけど採用されなかったあるある募集
あるあるbotに投稿したけど採用されなかったあるあるをこちらに投稿してください
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
特定のシート名のシートのみ除外して、それ以外のシート名のシートをすべて集約する方法(VBA)
Excel(エクセル)
-
VBAで指定シート以外の選択
Visual Basic(VBA)
-
【ExcelVBA】指定のシート以外を削除する方法
Visual Basic(VBA)
-
-
4
メッセージボックスに表示する文字を大きくしたい
Excel(エクセル)
-
5
Excel VBA 複数シートを別ファイルにコピーして保存
Excel(エクセル)
-
6
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
7
特定の文字を含むシートだけマクロ処理をしたい
Visual Basic(VBA)
-
8
エクセルのシート名変更で重複した時のvbaの処理
Visual Basic(VBA)
-
9
Excel VBA で特定のシートのみ除外
その他(Microsoft Office)
-
10
マクロの「SaveAs」でエラーが出るのを解消したいです(再)
Visual Basic(VBA)
-
11
特定の複数のシートに同じ処理をさせたい
Excel(エクセル)
-
12
【ExcelVBA】指定の書式で、マクロなしブックとしてAlertなしで別名保存する方法
Visual Basic(VBA)
-
13
【Excel VBA】複数ある特定の文字列を含む行を削除
Excel(エクセル)
-
14
vba マクロでファイル名をつけて保存するやり方を教えてください。 マクロで作成したエクセルファイル
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルの複数シートの保護を...
-
Excelで金銭出納帳。繰越残高を...
-
excelでシート毎の最終更新日を...
-
シートを追加・名前を次月に変...
-
Excelのシートを、まとめて表示...
-
エクセル 計算式も入っていない...
-
特定のシートの削除を禁止した...
-
エクセルで前のシートを連続参...
-
エクセルでファイルを開いたと...
-
Accessのスプレッドシートエク...
-
Excel、同じフォルダ内のExcel...
-
シートの保護のあとセルの列、...
-
エクセルのシート名をリスト化...
-
別シート参照のセルをシート毎...
-
前の(左隣の)シートを連続参...
-
エクセルVBAでパスの¥マークに...
-
エクセルで毎回1枚目のシートを...
-
VBAでシートコピー後、シート名...
-
EXCELで1ヶ月分の連続した日付...
-
Excelで同じシートのコピーを一...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルの複数シートの保護を...
-
Excelで金銭出納帳。繰越残高を...
-
エクセルVBAでパスの¥マークに...
-
前の(左隣の)シートを連続参...
-
EXCEL:同じセルへどんどん足し...
-
別シート参照のセルをシート毎...
-
エクセルでファイルを開いたと...
-
Excelのシートを、まとめて表示...
-
エクセルのシート名をリスト化...
-
VBAでシートコピー後、シート名...
-
特定のシートの削除を禁止した...
-
エクセルで前シートを参照して...
-
シートの保護のあとセルの列、...
-
エクセル 計算式も入っていない...
-
エクセルで複数設定したハイパーリンク先...
-
EXCELで1ヶ月分の連続した日付...
-
Excel、同じフォルダ内のExcel...
-
Accessのスプレッドシートエク...
-
EXCELで同一フォーマットのシー...
-
excelでシート毎の最終更新日を...
おすすめ情報