三流君 ken3のmemo置き場

三流プログラマーのメモ書きです。主にVBAやWindowsの話題が多いです

挨拶・自己紹介:
失敗続きのAB型の変わり者 :三流プログラマー Ken3です
フリーのエンジニア・個人事業主です・・と書くと聞こえはイイが(それとなくカッコよく聞こえるが)、 現在は小さな案件の受注請負 と 短期派遣 で 日々つつましく?ほそぼそと暮らしてます。

よく検索されるキーワード: [質問回答XXXXさんへ] [CreateObject] [VBA] [JRA競馬オッズ]

XXXXXさんへ VBA Outlook メールの移動について .ReceivedTimeで受信時刻がわかるので.Move してみただけ

下記の質問をいただく

OUTLOOKで受信したメールで作業実施日を毎朝8時とすると
>そこからからマイナス15時間から朝8時の範囲で受信したメールだけを
>任意のサブフォルダーに移したいときはどのようにすればよいのでしょうか。

.ReceivedTime で受信時刻がわかるので、
.Move してみただけですが

下記、メール移動のサンプルコードです
参考となれば・・・

Option Explicit

'2021-04-08 .Move でメールを移動させる
'カウンターを使用して、後ろからメールを処理する
Sub outlook_test20210408_001()

'サブフォルダからメールを読み込み 移動させる
    Dim oNamespace As NameSpace
    Dim oFolder As Outlook.Folder 'フォルダー
    
    ' NameSpace オブジェクトへの参照を取得します。
    Set oNamespace = Application.GetNamespace("MAPI")

    ' 既定のフォルダへの参照を取得し、フォルダを表示します。
    Set oFolder = oNamespace.GetDefaultFolder(olFolderInbox) '受信トレイを指定
    oFolder.Display   '選択したフォルダーの表示

    Dim mITEM       As Outlook.MailItem    'メールアイテム
    
    Dim nMAILCNT As Integer 'メールの位置 2019/06/06 追加

    'テストで名前の表示
    Debug.Print oFolder.Name

    'メールアイテムの処理 受信トレイがoFolderなので.Itemsで指定
    'メールの件数が .Count でわかるので、後ろから処理する
    For nMAILCNT = oFolder.Items.Count To 1 Step -1
        Set mITEM = oFolder.Items(nMAILCNT) 'アイテムを代入
        '↑.Item(nMAILCNT)の代入が終わったので、各プロパティに mITEM.XXXX で アクセスする
        
        'デバッグでイミディエイトに表示
        Debug.Print "件名:" & mITEM.Subject '件名表示
        Debug.Print "受信日時:" & mITEM.ReceivedTime '受信日時
        
        'メールを移動
        '受信日時を条件にして移動する
        '※6 ループの中で移動させる時は注意
        '受信日時 <= 15時間前の 過去メールなら、処理MOVETEST フォルダへ移動
        If mITEM.ReceivedTime <= DateAdd("h", -15, Now()) Then
        
            mITEM.Move oFolder.Folders("処理MOVETEST")  '受信トレイの下 処理MOVETEST
            Debug.Print ".move実行"
        End If
        Debug.Print ""
    Next

    '使用したオブジェクトの解放 = Nothing
    Set mITEM = Nothing
    
    Application.ActiveExplorer.Close   '新しく開いてしまったフォルダーを閉じる
    Set oFolder = Nothing
    Set oNamespace = Nothing

    MsgBox "処理終了"

End Sub


あっ
>そこからからマイナス15時間から朝8時の範囲で受信したメールだけを

'受信日時 <= 15時間前の 過去メールなら、処理MOVETEST フォルダへ移動
If mITEM.ReceivedTime <= DateAdd("h", -15, Now()) Then

↑当日、朝の八時の細工が必要ですね・・・
条件も逆ですね

'15時間前 <= 受信日時 <= 朝8時 の メールなら、処理MOVETEST フォルダへ移動
If DateAdd("h", -15, Now()) <= mITEM.ReceivedTime And mITEM.ReceivedTime <= 朝八時 Then
の条件にしないとダメですね。

メールの移動 .Moveは、後ろからループで処理しないと失敗するので
↓手前味噌ですが、下記の動画を暇な時みて笑ってください
www.youtube.com
https://www.youtube.com/watch?v=I4XZYWltfqA
↑ループ中にコレクションの内容が変化すると、不具合が起きます

やりたい作業、処理の参考となれば幸いです。 三流プログラマー Ken3


似たような処理
ken3memo.hatenablog.com
です。

Ken3 ホームページ 目次

分類:HPを大きく分けると4つの柱(分類)です。

  1. [VBA・マクロ プログラミング]の解説
    当店の人気はVBA系のCreateObject("XXXXXX.application")で他のアプリケーションを操作するサンプルが人気です
  2. [プログラマーの愚痴]では、あまり見せたくない三流プログラマーの内面かな。
    三流君を踏み台にする
  3. [古いクラシック ASP(Active Server Pages)]の解説。
  4. [元コンビニ店長時代の話]が弟に巻き込まれ、失敗した脱サラ、畑違い?の仕事で失敗。
主に上記4つの分類でHP作成やメルマガの発行を行ってます。
※更新頻度が落ちていて情報の鮮度が悪いです。



本当に三流なんです(笑):たまにスゴイですねなんて言われることもありますが、
真実は→ [三流君の真実は...] ←を初めに見てくださるとわかると思います。
(からくりは、成功例↑しか載せてなくて ヒドイ失敗例はお蔵入り迷宮入りが多かったりします)