Pythonを使ってPDFにハイパーリンクを追加する方法

PDF内のハイパーリンクは、ドキュメント内を移動するため、またはユーザーを外部リソースへ誘導するための透明で利用者に優しい方法を提供します。ハイパーリンクを組み込むことにより、PDFは静的な性質を超え、読者が特定のセクション、関連コンテンツ、または関連サイトに簡単にアクセスできるようになります。このインタラクティブ機能は、ユーザーの全体的な経験を向上させ、PDFドキュメントをよりダイナミックで魅力的で情報に富んだものにします。この記事では、Pythonを使用してPDFにハイパーリンクを追加する方法を探ります。

必要なライブラリのインストール

Pythonを使ってPDFにハイパーリンクを追加するプロセスを始める前に、まず必要なライブラリをインストールすることが重要です。この記事では、Spire.PDF for Pythonを使用します。Spire.PDF for PythonはPythonでPDFファイルを操作するための人気のあるライブラリで、ハイパーリンクの追加を含むPDFの既存の操作を可能にします。

このライブラリをインストールするには、プロジェクトの端末を開いて次のpipコマンドを実行します。

pip install Spire.Pdf

Pythonを使ってPDFにハイパーリンクを追加する

Spire.PDF for Pythonは、開発者がPDFに新しいテキストにハイパーリンクを追加することも、PDFの既存のテキストにハイパーリンクを追加することもできます。

例1: Pythonを使ってPDFの新しいテキストにハイパーリンクを追加する

次のコード例は、PythonとSpire.PDF for Pythonを使用してPDFドキュメントに様々なタイプのハイパーリンク(ウェブリンク、メールリンク、ファイルリンク)を追加する方法を説明します。

from spire.pdf.common import * 
from spire.pdf import * 

# PdfDocumentのインスタンスを作成 
pdf = PdfDocument() 

# ページを追加 
page = pdf.Pages.Add() 

# x, yの座標を初期化 
y = 30.0 
x = 10.0 

# TrueTypeフォントを作成 
font = PdfTrueTypeFont("Arial", 14.0, PdfFontStyle.Regular, True) 
font1 = PdfTrueTypeFont("Arial", 14.0, PdfFontStyle.Underline, True) 

# シンプルなリンクを追加 
label = "Simple Text Link: " 
format = PdfStringFormat() 
format.MeasureTrailingSpaces = True 
page.Canvas.DrawString(label, font, PdfBrushes.get_Orange(), 0.0, y, format) 
x = font.MeasureString(label, format).Width 
url = "http://www.e-iceblue.com" 
page.Canvas.DrawString(url, font1, PdfBrushes.get_Blue(), x, y) 
y = y + 28 

# ハイパーテキストリンクを追加 
label = "Hypertext Link: " 
page.Canvas.DrawString(label, font, PdfBrushes.get_Orange(), 0.0, y, format) 
x = font.MeasureString(label, format).Width 
webLink = PdfTextWebLink() 
webLink.Text = "Home Page" 
webLink.Url = url 
webLink.Font = font1 
webLink.Brush = PdfBrushes.get_Blue() 
webLink.DrawTextWebLink(page.Canvas, PointF(x, y)) 
y = y + 28 

# メールリンクを追加 
label = "Email Link:  " 
page.Canvas.DrawString(label, font, PdfBrushes.get_Orange(), 0.0, y, format) 
x = font.MeasureString(label, format).Width 
link = PdfTextWebLink() 
link.Text = "Contact Us" 
link.Url = "mailto:support@e-iceblue.com" 
link.Font = font1 
link.Brush = PdfBrushes.get_Blue() 
link.DrawTextWebLink(page.Canvas, PointF(x, y)) 
y = y + 28 

# ファイルリンクを追加 
label = "Document Link: " 
page.Canvas.DrawString(label, font, PdfBrushes.get_Orange(), 0.0, y, format) 
x = font.MeasureString(label, format).Width 
text = "Open File" 
location = PointF(x, y) 
size = font1.MeasureString(text) 
linkBounds = RectangleF(location, size) 
fileLink = PdfFileLinkAnnotation(linkBounds,"C:\\Users\\Administrator\\Desktop\\Report.xlsx") 
fileLinkBordure = PdfAnnotationBorder(0.0) 
page.AnnotationsWidget.Add(fileLink) 
page.Canvas.DrawString(text, font1, PdfBrushes.get_Blue(), x, y) 

# PDFファイルを保存 
pdf.SaveToFile("AddLinkstoPDF.pdf") 
pdf.Close() 

例2: Pythonを使ってPDFの既存のテキストにハイパーリンクを追加する

次のコード例は、PythonとSpire.PDF for Pythonを使用してPDFドキュメントの既存のテキストにハイパーリンクを追加する方法を説明します。

from spire.pdf.common import * 
from spire.pdf import * 

# PdfDocumentのインスタンスを作成 
pdf = PdfDocument() 

# PDFファイルを読み込み 
pdf.LoadFromFile("input.pdf") 

# 最初のページを取得 
page = pdf.Pages[0] 

# ページ内で特定のテキストの全ての発生を検索 
collection = page.FindText("big O notation", TextFindParameter.IgnoreCase) 

# 指定されたテキストの全ての発生を通過 
for find in collection.Finds: 
    # ハイパーテキストリンクのアノテーションを作成 
    uri = PdfUriAnnotation(find.Bounds) 
    # リンクのURLを定義 
    uri.Uri = "https://en.wikipedia.org/wiki/Big_O_notation" 
    # リンクアノテーションのボーダーを定義 
    uri.Border = PdfAnnotationBorder(1.0) 
    # ボーダーの色を定義 
    uri.Color = PdfRGBColor(Color.get_Blue()) 
    # ページにハイパーテキストリンクアノテーションを追加 
    page.AnnotationsWidget.Add(uri) 

# 結果のファイルを保存 
pdf.SaveToFile("SearchTextAndAddHyperlink.pdf") 
pdf.Close() 

これらのコード例は、PythonとSpire.PDFライブラリを使用して、PDFドキュメントにハイパーリンクを追加する方法を示しています。これらの例に従えば、PDFファイルのインタラクティビティとユーザーエクスペリエンスを向上させることができます。

関連トピック