📘 Excel逆引き事典

【VBA】ハイパーリンクを確認メッセージ無しで転記する方法

日々の業務でハイパーリンク情報を手動で移動させることは時間と労力を必要とします。この記事では、VBAを使用してハイパーリンクを別のセルに自動的に転記し、確認メッセージを表示せずに高速化する方法を紹介します。

サンプルコード

VBA
Option Explicit
Sub HyperlinkCopyWithoutAlert()
    Dim ws As Worksheet
    Set ws = ThisWorkbook.Sheets("Sheet1")
    
    ' ハイパーリンクが存在する最後の行を取得
    Dim lastRow As Long
    lastRow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row
    
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    
    ' ハイパーリンクのあるセルから転記先のセルへコピー
    Dim i As Long
    For i = 2 To lastRow ' 假设从第二行开始有数据,第一行为标题行
        If ws.Cells(i, 1).Hyperlinks.Count > 0 Then ' 检查是否有超链接
            ws.Hyperlinks.Add Anchor:=ws.Cells(i + 1, 1), Address:=ws.Cells(i, 1).Hyperlinks(1).Address, TextToDisplay:=ws.Cells(i, 1).Value ' 转移到下一个单元格,假设转到同一列的下一行
        End If
    Next i
    
    Application.ScreenUpdating = True
    Application.DisplayAlerts = True
End Sub

よくある質問

Q 元に戻せますか?

A.
VBAの実行結果は「元に戻す」が効きません。必ずバックアップを取ってから実行してください。

Q エラーが出たら?

A.
シート名や列番号が正しいか確認してください。