Excel VBAでフォルダ内のファイル名を一括修正する方法

Excel VBAを使用して、ファイル名の誤字や脱字を一括で修正する方法について詳しく説明します。この記事を通して、Excel VBAの力強さを再確認することができるでしょう。また、日常の業務での小さな手間をVBAで自動化する方法もご紹介します。

目次

Excel VBAの基本

Excel VBA(Visual Basic for Applications)は、Microsoft Excelに組み込まれたプログラミング言語です。これを用いると、単純作業の自動化だけでなく、高度なデータ分析やレポート作成も可能になります。

そもそも、どこにVBAコードを書いて、どう実行すれば良いのか分からない場合は、以下の記事をご参照ください。

Excel VBAによるファイル名の一括修正

Excel VBAを使えば、フォルダ内の多数のファイル名の誤字や脱字を短時間で修正することが可能です。ここでは、基本的なコードとその動作の解説、さらに応用例を紹介します。

基本的なコード

以下は、指定したフォルダ内のファイル名を一括で修正するためのVBAコードの例です。


Sub RenameFilesInFolder()
    Dim folderPath As String
    Dim fileName As String
    Dim newName As String
    'フォルダのパスを指定
    folderPath = "C:\ExampleFolder\"
    fileName = Dir(folderPath & "*.*")
    '各ファイルに対しての処理
    Do While fileName <> ""
        '新しいファイル名を生成(ここでは"old"を"new"に変更する例)
        newName = Replace(fileName, "old", "new")
        Name folderPath & fileName As folderPath & newName
        fileName = Dir
    Loop
End Sub

コードの詳細解説

上記のコードは、指定したフォルダ内のすべてのファイルに対して、ファイル名中の”old”という文字列を”new”という文字列に変更する処理を行います。

1. `folderPath`で操作したいフォルダのパスを指定します。
2. `Dir`関数を使用して、フォルダ内の最初のファイル名を取得します。
3. `Do While`ループを使用して、フォルダ内のすべてのファイルを順に処理します。
4. `Replace`関数を使って、既存のファイル名から新しいファイル名を生成します。
5. `Name`文を使って、ファイル名を変更します。
6. 最後に、次のファイル名を取得してループを続けます。

応用例

1. 特定の拡張子のファイルのみを対象にする

特定の拡張子(例:.txt)のファイルのみを対象にしたい場合のコード例です。


fileName = Dir(folderPath & "*.txt")

2. ファイル名に日付を追加する

ファイル名の先頭に今日の日付を追加する例です。


newName = Format(Date, "yyyymmdd") & "_" & fileName

3. ファイル名の特定の位置の文字を変更する

例えば、ファイル名の3文字目と4文字目を”AB”に変更する場合のコード例です。


newName = Left(fileName, 2) & "AB" & Mid(fileName, 5)

まとめ

Excel VBAを使ってフォルダ内のファイル名を一括で効率的に変更する方法を学びました。この技術を使うことで、日常の業務で発生する煩雑な作業を効率化し、生産性を向上させることが可能です。是非、これをきっかけにExcel VBAのさまざまな機能を活用してみてください。

VBAも良いけどパワークエリも良い

VBAの解説をしてきましたが、VBAは正直煩雑でメンテナンス性が悪いです。最近はモダンExcelと呼ばれるパワークエリやパワーピボットへのシフトが進んできています。本サイトでもパワークエリの特集をしており、サンプルデータを含む全11回の学習コンテンツでパワークエリを習得することができます。

クリックするとパワークエリの全11講座が表示されます。

パワーピボットの記事はありません。興味がある場合は、書籍で学んでみてください

コメント

コメントする

目次