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

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

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

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

Q&A

解決済

4回答

285閲覧

メールに添付したファイルを消す必要があるのかを知りたいです。

rokku

総合スコア12

VBA

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

0グッド

0クリップ

投稿2024/03/25 10:11

編集2024/03/26 01:47

分からないこと

下記プログラムは、ある学習サイトを参考に簡単に作成したものです。
(有料サイトで会員の方しか閲覧できないため、URLは記載しておりません。)
9行目の.Attachments(1).deleteをしなければ、
Outlookアプリの指定された保存場所に添付ファイルが残ってしまうままなのでしょうか?
目的は、Outlookアプリの保存容量削減のためです。

宜しくお願いいたします。

該当のソースコード

VBA

1sub a() 2 strAttachZipPath = "C:\ccc.zip" 3 With CreateObject("Outlook.Application").CreateItem(0) 4 .To = "hogepiyo@fugafuga.com" 5 .Subject = "AAAA" 6 .Body = "BBBBBB" 7 .Attachments.Add strAttachZipPath 8 .Send 9 .Attachments(1).delete 10 End With 11 Kill strAttachZipPath 12end sub

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

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

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

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

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

ikedas

2024/03/25 15:07 編集

そのサイトの該当ページのURL を明記してください (このコメント欄に書くのではありません。質問文を編集して書いてください)。
guest

回答4

0

必要かどうかは目的次第です。「~~~~という目的のために必要か?」という質問でないと意味を為しません。
「メールを送るために必要か?」であれば、メールを送った後の話なので、必要無いに決まっています。削除しても削除しなくても送付先には影響しません。
「メール送付後、送信済みフォルダーに入った送ったメールから、添付ファイルを削除したいという目的のために必要か?」であれば、削除したいのだから必要に決まっています。
「メール送付後、送信済みフォルダーに入った送ったメールを送った時のまま残しておきたいという目的のために必要か?」であれば、削除しちゃ駄目です。
「メール送付後、そのメールを手元に残したくない。消えて欲しいという目的のために必要か?」であれば、添付ファイルの削除だけでは不十分で、.Attachments(1).deleteじゃなくて.deleteでメール全体を削除でしょうか。
(Microsoft製品は排他制御がおかしいことがあるので、変なエラーになるかも知れませんが)

投稿2024/03/25 18:55

otn

総合スコア84566

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

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

rokku

2024/03/26 01:48

ご回答ありがとうございます。 質問が分かりづらくて申し訳ございません。 質問を編集致しましたので、お手数お掛けして申し訳ございませんが、 再度ご確認のほど宜しくお願いいたします。
guest

0

必要かどうかは運用側の問題では?
VBAでコントロールできるメーラーは限られているので実効性は高くないと思います

投稿2024/03/25 11:12

yambejp

総合スコア114843

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

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

0

自己解決

ソースコードの一部しか書いておらず、申し訳ございません。
ループ処理をしており、添付ファイルを削除しないと、
次のメールを送信する時に前にメールした時に添付したファイルがくっついてしまうことが分かりました。
次に質問する時は、質問内容に気を付けて、質問するように致します。
今後とも宜しくお願いいたします。

投稿2024/03/26 01:58

rokku

総合スコア12

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

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

otn

2024/03/26 04:56

ループ処理部分が書かれてませんが、毎回CreateItemで新規にメールを作っているのであればそんなことにはならないはずです。 CreateItemを一度しかせずに1つのメールをループで使い回しているなら、添付ファイルの追加などの変更は累積していくのでしょうね。
rokku

2024/03/26 06:25 編集

ご回答ありがとうございます。 >毎回CreateItemで新規にメールを作っているのであればそんなことにはならないはずです。 → おっしゃる通りで上記の方法で試してみたところ、   前回送信した添付ファイルが追加されずに送信することができました。   otnさんのおかげで新しい視点を発見することができました。ありがとうざいます。 >CreateItemを一度しかせずに1つのメールをループで使い回しているなら、 → おっしゃる通りで1度のみ、CreateItemを行っておりました。
guest

0

ソースコードの一部しか書いておらず、申し訳ございません。
ループ処理をしており、添付ファイルを削除しないと、
次のメールを送信する時に前にメールした時に添付したファイルが
くっついてしまうことが分かりました。
次に質問する時は、質問内容に気を付けて、質問するように致します。

今後とも宜しくお願いいたします。

投稿2024/03/26 01:57

rokku

総合スコア12

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問