ExcelマクロVBAサンプル集 | ハイパーリンクからファイルのフルパスを取得する | Excelマクロの実用サンプル、エクセルVBA集と解説



最終更新日:2014-12-04

ハイパーリンクからファイルのフルパスを取得する

ハイパーリンクのリンク先ファイル情報を取得しようとすると、なかなか難しいことになります、
ハイパーリンクからパスを取得すると相対パスとなり、簡単にはファイル情報を取得出来ません。

以下のサンプルでは、ハイパーリンクの設定されているセルの右隣のセルに更新日時を出力しています。

Sub sample()
  Dim rng As Range
  Dim FileName As String
  Dim fso As New FileSystemObject

  ChDir ThisWorkbook.Path
  For Each rng In ActiveSheet.UsedRange
    If rng.Hyperlinks.Count > 0 Then
      FileName = fso.GetAbsolutePathName(rng.Hyperlinks(1).Address)
      If fso.FileExists(FileName) Then
        rng.Offset(0, 1) = fso.GetFile(FileName).DateLastModified
      End If
    End If
  Next
End Sub


※「ツール」→「参照設定」で、「Microsoft Scripting Runtime」にチェックを付けて下さい。

参照設定しない場合は、
Dim fso As Object
Set fso = CreateObject("Scripting.FileSystemObject")

このようにしてください。

ChDir ThisWorkbook.Path
事前にこれを行うことで、
GetAbsolutePathName
これで絶対パスを取得できます。
後は普通に、FSOで各種情報を取得してください。


最初からハイパーリンクを絶対パスで保存する方法もあります。
設定をこれに変更した後に作成したハイパーリンクのみ絶対参照で保存されます。
設定前に作成したハイパーリンクは相対パスのままになるので注意してください。

一応、ハイパーリンクが絶対パスで保存されている場合の、
上のノマロと同様の機能のVBAコードも掲載しておきます。

Sub sample2()
  Dim rng As Range
  Dim FileName As String

  For Each rng In ActiveSheet.UsedRange
    If rng.Hyperlinks.Count > 0 Then
      FileName = rng.Hyperlinks(1).Address
      If Dir(FileName) <> "" Then
        rng.Offset(0, 1) = FileDateTime(FileName)
      End If
    End If
  Next
End Sub


こちらは、FSOを使うまでもないので、
Dir

FileDateTime
これで済ませています。




同じテーマ「ExcelマクロVBAサンプル集」の記事

ボタンのテキスト名のシートへ移動(Application.Caller)
Excelの表をPowerPointへ図として貼り付け
連続セル範囲の選択
1行置きにする行挿入(Insert)
ユーザー定義関数でフリガナを取得する(GetPhonetic)
ユーザー定義関数でハイパーリンクのURLを取得(Hyperlink)
カラーのコード取得、256RGB⇔16進変換

新着記事 ・・・新着記事一覧を見る

ファイルの一覧取得・削除(File)|Google Apps Script入門(1月24日)
フォルダの一覧取得・作成・削除(Folder)|Google Apps Script入門(1月24日)
フォルダとファイルを扱う(DriveApp)|Google Apps Script入門(1月24日)
スプレッドシートが非常に遅い、高速化するには|Google Apps Script入門(1月17日)
画像のトリミング(PictureFormat,Crop)|ExcelマクロVBAサンプル集(12月27日)
シート保護|Google Apps Script入門(12月24日)
表示の固定|Google Apps Script入門(12月24日)
グラフ|Google Apps Script入門(12月21日)
入力規則|Google Apps Script入門(12月13日)
並べ替え|Google Apps Script入門(12月12日)

アクセスランキング ・・・ ランキング一覧を見る

1.RangeとCellsの使い方|ExcelマクロVBA入門
2.最終行の取得(End,Rows.Count)|ExcelマクロVBA入門
3.徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)|エクセル関数超技
4.Range以外の指定方法(Cells,Rows,Columns)|ExcelマクロVBA入門
5.セルの参照範囲を可変にする(OFFSET,COUNTA,MATCH)|エクセル関数超技
6.セルのコピー&値の貼り付け(PasteSpecial)|ExcelマクロVBA入門
7.ひらがな⇔カタカナの変換|エクセル基本操作
8.CSVの読み込み方法|ExcelマクロVBAサンプル集
9.変数とデータ型(Dim)|ExcelマクロVBA入門
10.VBAのFindメソッドの使い方には注意が必要です|ExcelマクロVBA技術解説



  • >
  • >
  • >
  • ハイパーリンクからファイルのフルパスを取得する

  • このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


    記述には細心の注意をしたつもりですが、
    間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
    なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。

    ↑ PAGE TOP