【VBA】セルを選択したらCSVファイルを開くマクロ|G列の選択でE列のファイル名と連動

目次

概要

Excelで作業していると、特定のセルを選択したときに、自動で関連ファイルを開きたくなる場面がありますよね。
今回は、「G2〜G100のセルにカーソルを合わせたときに、対応するCSVファイルを自動で開くVBAマクロ」をご紹介します。

  • CSVファイルは指定のフォルダに保存
  • E列にファイル名(拡張子なし)を記載
  • G列のセルに「開く」と記載された行がトリガー

このような仕様で、マウス操作だけでCSVファイルをすぐに開ける便利なマクロを実装できます。


実現する仕様

  • G2~G100のセルを選択したときに動作
  • 同じ行のE列に記載されたファイル名をもとにCSVファイルを検索
  • メッセージボックスで確認後、CSVファイルを開く
  • ファイルが存在しない場合は警告を表示

前提準備

  1. CSVファイルを保存しているフォルダを用意
  2. Excelの**E列に「ファイル名(拡張子なし)」**を記入
  3. G列の任意の行に「開く」と入力(これがトリガーになります)

VBAコード全文(ワークシートモジュール)

以下のコードをVBAエディタの対象ワークシート(例:Sheet1)モジュールに貼り付けてください。

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    ' G列の特定のセルが選択されたかどうかをチェック
    If Not Intersect(Target, Me.Range("G2:G100")) Is Nothing Then
        If Target.Value = "開く" Then
            Dim code As String
            code = Me.Cells(Target.Row, "E").Value
            
            ' CSVファイルが格納されているフォルダパスを設定
            Dim csvFolderPath As String
            csvFolderPath = "C:\Users\YourName\Documents\CSVフォルダ\" ' ←適宜変更
            
            Dim csvFilePath As String
            csvFilePath = csvFolderPath & code & ".csv"
            
            If Len(Dir(csvFilePath)) > 0 Then
                Dim MsgResponse As VbMsgBoxResult
                MsgResponse = MsgBox(code & ".csv のファイルを開きますか?", vbQuestion + vbYesNo, "確認")
                
                If MsgResponse = vbYes Then
                    Workbooks.Open Filename:=csvFilePath
                End If
            Else
                MsgBox code & ".csv が見つかりません。", vbExclamation
            End If
        End If
    End If
End Sub

注意点

  • csvFolderPath に指定するパスは、末尾の \ を忘れずに入力してください
  • 相対パスではなく、絶対パスでの指定をおすすめします
  • .csv の拡張子を含めるため、E列には拡張子なしのファイル名だけを記載してください

まとめ

  • G列を選択するだけで、E列に対応するCSVファイルを開ける
  • ファイル存在確認 → メッセージ表示 → ユーザー確認 → 開く、という安全な流れ
  • 業務効率化や作業の省力化に最適なVBA活用法

「ファイルを探す」「開く」の繰り返し作業を、クリック1つに自動化してみませんか?
ここまでお読みいただきありがとうございました。参考になれば幸いです。

スクールの紹介

最後に宣伝をさせてください。

技術で未来を切り拓く―あなたの夢を現実にするプログラミングスクール

Webデザインやプログラミングで成功を目指している方々にとって、このオンラインスクールは夢を叶えるための最適な場所です。皆さんのキャリアを次の段階へと引き上げるためにデザインされたこのスクールは、一人ひとりの成功を心から願い、それを実現するための全てを提供しています。ここでは、このスクールの魅力について詳しくご紹介します。

◆圧倒的な費用対効果
このオンラインプログラミングスクールは、Web系教育において最高の費用対効果を提供しています。多くの高額スクールが存在する中で、ここではリーズナブルな価格で、質の高い教材、無限のサポート、そして実際に市場で求められるスキルの習得機会を提供しています。

◆現役フリーランスの講師陣
講師たちは全員、現役のフリーランスプロフェッショナルです。市場で活躍している講師から直接、最新のトレンドや実践的なスキルを学べるのは、このスクールの大きな特徴です。

◆柔軟な学習コース
固定のコースがなく、学習者の興味やニーズに応じて自由に学習できます。進路変更も自由で、最低契約期間は1ヶ月という柔軟性を持っています。自分のペースで、自分に合った学習が可能です。

◆無制限の添削とサポート
理解できるまで、そして満足するまで、無制限に添削と質問への回答を提供しています。進路相談や技術面以外の相談にも対応しており、全面的にサポートします。

◆社長から学べる貴重な機会
デザイナー、プログラマー、ディレクター、マーケターとして豊富な経験を持つ社長から直接学べるのも、このスクールの特別な点です。他のスクールでは得られない、貴重な機会です。

◆実績作りへの徹底的なサポート
就職、転職、フリーランスとして成功するためには、高品質な実績が必要です。生徒の作品レベルを最大限に高め、市場で求められる実績を作り上げることに力を入れています。案件を取得できない生徒には、直接案件を提供することもあります。

◆メッセージからの約束
高額な授業料を支払わせて結果を出せないスクールとは違い、物理的なサポートは提供できないかもしれませんが、継続的な努力を通じて最高の結果を出せるようにサポートします。一緒に不正なスクールを撲滅し、あなたの夢を実現しましょう。

このプログラミングスクールは、Webデザインやプログラミングでの成功を目指す方々に必要な全てを備えています。今こそ、このコミュニティに参加し、あなたのキャリアを加速させる時です。

詳しくはこちら↓

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

この記事を書いた人

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

目次