
こんにちは。
以前、このような質問があり、
自分でもこれを元にプログラムを書いてみました。
http://oshiete1.goo.ne.jp/kotaeru.php3?q=1652780
問題は、添付するファイルの名前が変わるので
どうすれば毎回変化する名前のファイルが
きちんと添付できるかというのが質問です。
アスタリスク(*)はVBAでは使えないとのこと。
正規表現?というのを使用するのでしょうか?
※下のAttFile = "D:\教えて01.txt"を例にすると「教えて02,教えて03・・・」と
毎回ファイル名が変わるものとして下に書きました。
ここの記述はどのようにすればよいのでしょうか?
環境はWindowsXP
Office2003
BASP21というのを使用しています。
Sub SendMail()
Dim B21Obj, MailContents
Dim Server, Mailto, MailFrom, Title, Body, AttFile
If Range("A1") = "" Then GoTo Fin
If Range("A2") = "" Then GoTo Fin
If Range("A3") = "" Then GoTo Fin
Set B21Obj = CreateObject("basp21")
Server = "***.***.com" 'サーバー名(ご自分のSMTPサーバーに書換え)
Mailto = Range("A1").Value & vbTab & "bcc" & vbTab & "***@***.ne.jp" '宛先
MailFrom = "***@***.com" '差出し人(ご自分のメールアドレスに書換え)
Title = Range("A2").Value 'タイトル
Body = Range("A3").Value '本文
AttFile = "D:\教えて01.txt" '添付書(01,02,03・・・と毎回変わります)
MailContents = B21Obj.SendMail(Server, Mailto, MailFrom, Title, Body, AttFile)
Fin:
Set B21Obj = Nothing
Range("A1").Select
End Sub
No.3ベストアンサー
- 回答日時:
>どのように組み込むか
単純に・・・
Sub SendMail()
:
AttFile = "D:\教えて" & Format(Now(), "yymmdd") & Format(Range("L10").Value) & ".txt"
Name "D:\教えて01.txt" As AttFile
:
End Sub
hana-hana3様!
昨日につづきご回答ありがとうございました!
動作も上手くいきました!!
この4月より会社で部署が変わり
このVBAをやることになりまして・・・
VBA歴10日余り・・・
この感謝を忘れません!
皆様ありがとうございました!
No.2
- 回答日時:
単純に 01 部分を指定したいなら、そこを変数にするだけです。
Sub Test1()
Dim myNum
myNum = Application.InputBox("D:\教えて?.txt", "指定", Type:=2)
If myNum <> False Then MsgBox "D:\教えて" & myNum & ".txt"
End Sub
やはりファイルを選ばせるのが普通でしょうか、、、
Sub Test2()
Dim fName
ChDrive "D:\": ChDir "D:\"
fName = Application.GetOpenFilename("テキスト ファイル (*.txt), *.txt")
If fName <> False Then MsgBox "選択されたファイル: " & fName
End Sub
papayuka様
ご回答ありがとうございました。
test2は理想的です!
元のSub SendMail()に
どのように組み込むか
ご教授願えないでしょうか?
よろしくお願いいたします!!
No.1
- 回答日時:
>どうすれば毎回変化する名前のファイルがきちんと添付できるかというのが質問です
毎回変化する理由は?
変化したファイル名を取得する手段は?
等、ファイル名を取得できるタイミング(方法)の有無。
ファイル名の取得には、
1.DIR関数でフォルダの全ファイル名を取得
2.ファイルダイアログでファイルの選択
3.セルに記述
など、いくつかの手段があります。
この回答への補足
hana-hana3様
早速のご回答ありがとうございました!
>毎回変化する理由は?
>変化したファイル名を取得する手段は?
具体的には下のようなものを先に書いて、あえてファイル名を変えてから、メール送信をしたいと考えています。
Sub rename()
Name "D:\教えて01.txt" As "D:\教えて" & Format(Now(), "yymmdd") & Format(Range("L10").Value) & ".txt"
End Sub
恐れ入りますが、
よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAが止まります。 3 2022/08/31 14:09
- Visual Basic(VBA) VBAでoutlook365が起動しません。 4 2022/08/25 13:31
- Visual Basic(VBA) 【追加】ファイルを閉じてダイアログで保存した時だけ処理の実行をする 3 2022/03/23 15:43
- Visual Basic(VBA) このVBAでExcelアプリケーションを作成は必要ですか? 3 2023/07/19 21:13
- Visual Basic(VBA) エクセルのマクロを使ってメールを送る方法について教えてください 2 2022/03/29 01:36
- Visual Basic(VBA) 【前回の続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/16 16:44
- Visual Basic(VBA) エクセルVBAのコードで質問です。 下のコードはJ16の文字列をB3を起点とする範囲から探して、見つ 5 2023/04/07 11:07
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Visual Basic(VBA) 配列の勉強をしています。使用する変数の意味、検索条件の書き方が難しいです。 2 2022/09/15 14:06
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
このQ&Aを見た人はこんなQ&Aも見ています
-
【Excel VBA】ファイル名が一定でないファイルの指定方法
Excel(エクセル)
-
VBAのフォント変更(エクセルからoutlookのメール作成において)
Visual Basic(VBA)
-
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
-
4
エクセルマクロで不特定なファイル名を使用するには
Excel(エクセル)
-
5
excelのマクロで該当処理できなければ飛ばして進むにはどうすればよいのでしょうか
Visual Basic(VBA)
-
6
マクロ初心者です。 マクロで範囲選択したセルをOutlookのメールの本文に貼り付けたいのですがなか
Visual Basic(VBA)
-
7
【Excel VBA】マクロでExcel自体を終了させたい
Excel(エクセル)
-
8
【Excel】 シート内のデーターでメール送信したい。
Excel(エクセル)
-
9
エクセルVBA:毎月名前が変わるエクセルファイルを毎月異なるフォルダから開く
その他(コンピューター・テクノロジー)
-
10
個別に違う添付ファイルを付けて一括でメール配信をしたいのですが、EXC
Visual Basic(VBA)
-
11
アクセスVBAでメールを送信(複数宛先・添付)
その他(パソコン・スマホ・電化製品)
-
12
名前をつけて保存した後、元のファイルに戻るには
その他(コンピューター・テクノロジー)
-
13
VBAのオートフィルターで該当行がない場合に処理を止めたい
Excel(エクセル)
-
14
Excelマクロ ファイル名が変わるとエラーになる
Excel(エクセル)
-
15
SQL文で パラメータが少なすぎます エラー
Access(アクセス)
-
16
名前の変わるブックをアクティブにしたい。
Excel(エクセル)
-
17
VBAでファイルを開くときにファイル名でワイルドカードを使用したいです
その他(プログラミング・Web制作)
-
18
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
19
vba初心者です。 質問です。 毎回ファイル名が変わるファイルを開きたいです。 open filen
その他(IT・Webサービス)
-
20
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
バッチ処理でファイルの中身を...
-
.txtではなく.logの方が良いの...
-
VBAでワークシートを引数として...
-
テキストファイルで提出とは?
-
ファイル内容の修正、行削除に...
-
renameコマンドについて
-
UWSCでテキストファイルを開い...
-
エクセルの各セルの内容をそれ...
-
拡張子を元に戻す
-
ファイル名の一部をbatで変更し...
-
多数のサブディレクトリ内のフ...
-
「***.txt」 から 「***.pl」...
-
psqlでエラーログをとりたい
-
バッチファイルからVBAに引数を...
-
ADODB.Streamで開いたファイル...
-
Windows マシンでFTPバッチが動...
-
バッチファイルについて
-
バッチファイルで文字列削除に...
-
javaで大量のファイルを読み込...
-
3つ以上のテキストファイルをコ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
バッチ処理でファイルの中身を...
-
.txtではなく.logの方が良いの...
-
VBAでワークシートを引数として...
-
多数のサブディレクトリ内のフ...
-
COPYコマンドで結合すると余計...
-
バッチファイル 複数ファイル...
-
psqlでエラーログをとりたい
-
ファイル内容の修正、行削除に...
-
バッチファイルで文字列削除に...
-
テキストファイルで提出とは?
-
拡張子を元に戻す
-
ファイルの最後に文字列挿入
-
UWSCでテキストファイルを開い...
-
エクセルの各セルの内容をそれ...
-
ファイル名の一部をbatで変更し...
-
renameコマンドについて
-
accessでSQL文を使ってcsvファ...
-
3つ以上のテキストファイルをコ...
-
Windowsのバッチファイルを利用...
-
ファイルのワイルドカードについて
おすすめ情報