【VBA】Wordテーブル内で今日以前の日付行を削除する方法|期限切れの行を自動で整理

Wordで日付付きのテーブルを使っていると、「すでに過ぎた日付の行を削除したい」というケースがありますよね。
今回は、WordのVBAを使って、今日より前の日付が記載された行を自動で削除するコードをご紹介いたします。


目次

実現したいこと

  • Wordの表(テーブル)で、1列目に日付、2列目に担当者という構成
  • 「今日以前」の日付が入った行を削除して、最新の予定だけ残したい
  • 日付形式は「2023年12月1日」などの日本語表記を使用

処理対象のテーブルイメージ

日付担当者
2023年11月27日
2023年12月1日小森
2023年12月11日中森

この中から「11月27日」の行を削除したい、という目的です。


使用するVBAコード

以下のコードを実行すると、テーブルの2行目以降を上から確認し、今日以前の日付があれば行ごと削除します。

Sub UpdateTable()
    Dim doc As Document
    Set doc = ActiveDocument

    Dim tbl As Table
    Set tbl = doc.Tables(1) ' 最初のテーブルを対象

    Dim i As Integer
    For i = tbl.Rows.Count To 2 Step -1 ' 下から上へループ(2行目から)
        Dim dateString As String
        dateString = tbl.Cell(i, 1).Range.Text
        dateString = Trim(Left(dateString, Len(dateString) - 2)) ' 改行コードを削除

        ' "yyyy年mm月dd日" → "yyyy/mm/dd" に変換
        dateString = Replace(dateString, "年", "/")
        dateString = Replace(dateString, "月", "/")
        dateString = Replace(dateString, "日", "")

        If IsDate(dateString) Then
            If CDate(dateString) < Date Then
                tbl.Rows(i).Delete
            End If
        End If
    Next i
End Sub

コードのポイント解説

  • tbl.Rows.Count To 2 Step -1
    → 上から削除すると行番号がずれるため、下から削除する方式を採用
  • Trim(Left(...))
    → Wordのテーブルセルには末尾に改行コードが含まれるため、必ず除去
  • Replace("年", "/")などの置換
    → ExcelやVBAのCDate関数では「yyyy/mm/dd」形式の方が正しく日付変換できる
  • If CDate(dateString) < Date Then
    今日以前の日付かどうかをチェックして、該当すれば削除

注意点

  • この処理は、最初のテーブル(Tables(1))が対象になります
    他のテーブルを対象にしたい場合は、doc.Tables(2)などに変更してください
  • 1列目のセルに日付以外が入っている行があると、IsDate() で判定されないためスキップされます
  • 削除対象は**あくまで「今日より前の日付」**です。「今日を含める」には条件を <= Date に変更してください

まとめ

Wordで予定表などを管理している場合、すでに終わった日付の行を手動で削除するのは手間がかかります。
VBAを使えば、ボタン1つで最新の行だけ残してテーブルを整理できます。

  • CDate + IsDate を使えば、日付判定が簡単
  • 「年/月/日」に変換することで、日本語表記の扱いにも対応
  • テーブル行の削除は下から処理するのが基本

業務報告書や管理表などに活用されている方は、ぜひお試しください。
最後までお読みいただき、ありがとうございました。

副業から独立まで「稼げる」Webスキルを習得する(PR)

ここまで読んでいただきありがとうございます。 最後に宣伝をさせてください。

「副業を始めたいが、何から手をつければいいかわからない」「独学でスキルはついたが、収益化できていない」という悩みを持つ方には、マンツーマン指導のWebスクール**「メイカラ」**が適しています。

このスクールは、単に技術を教えるだけでなく、**「副業として具体的にどう稼ぐか」**という実務直結のノウハウ提供に特化している点が特徴です。

講師陣は、実際に「副業Webライターから1年で独立して月収100万円」を達成したプロや、現役で利益を出し続けているブロガーなど、確かな実績を持つプレイヤーのみで構成されています。そのため、机上の空論ではない、現場で通用する戦術を学ぶことができます。

副業に特化した強み

  • 最短ルートの提示: 未経験からでも実績を出せるよう、マンツーマンで指導。
  • AI活用の習得: 副業の時間対効果を最大化するための、正しいAI活用スキルも網羅。
  • 案件獲得のチャンス: 運営がWebマーケティング会社であるため、実力次第で社内案件の紹介など、仕事に直結する可能性があります。

受講者の多くは、「在宅でできる仕事を探している」「副業を頑張りたい」という20代・30代・40代が中心です。

受講前には、講師による無料説明が行われます。無理な勧誘はなく、自分に合った副業スタイルやプランを相談できるため、まずは話を聞いてみることから始めてみてはいかがでしょうか。

ブログで稼ぎたいなら「メイカラ」

よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!

この記事を書いた人

私が勉強したこと、実践したこと、してることを書いているブログです。
主に資産運用について書いていたのですが、
最近はプログラミングに興味があるので、今はそればっかりです。

目次