🎯 カスタマイズ可能で検出回避型のクラウドブラウザ。自社開発のChromiumを搭載し、ウェブクローラーAIエージェント向けに設計されています。👉今すぐ試す
ブログに戻ります

ウェブスクレイピングのためのランダムIP生成方法

Michael Lee
Michael Lee

Expert Network Defense Engineer

23-Sep-2025

はじめに
ランダムなIPを生成することは、ウェブスクレイピングにとって重要です。IPの回転がなければ、あなたのリクエストはブロックされるリスクがあります。このガイドでは、PythonでランダムなIPを生成するための10の実用的な方法を探ります。より簡単で信頼性の高いアプローチを望む場合は、Scrapelessの使用を考慮してください。これはIPの回転を自動化します。


1. 静的なIPリストを使用する

結論: 事前に定義されたリストから簡単にランダム選択できます。

手順:

  1. IPのリストを作成します(ips = ["192.168.1.1", "192.168.1.2"])。
  2. random.choice()を使用して選択します。
python Copy
import random

ips = ["192.168.1.1", "192.168.1.2", "192.168.1.3"]
random_ip = random.choice(ips)
print(random_ip)

アプリケーション: 制御されたIPのセットを使用した小規模なスクレイピングタスク。


2. ランダムIP生成を使用する

結論: プログラムでIPを生成し、変動性を高めます。

手順:

python Copy
import random

def random_ip():
    return ".".join(str(random.randint(1, 254)) for _ in range(4))

print(random_ip())

アプリケーション: IPの評判が重要でないテストや一時的なスクレイピングタスクに。


3. 無料の公共プロキシを回転させる

結論: 無料プロキシは即座にランダムなIPを提供します。

手順:

  1. 公共のソースからプロキシリストを取得します。
  2. リクエストに使用するプロキシをランダムに選択します。
python Copy
import requests, random

proxies = ["http://111.111.111.111:8080", "http://222.222.222.222:8080"]
proxy = random.choice(proxies)
response = requests.get("https://example.com", proxies={"http": proxy, "https": proxy})

アプリケーション: 低予算での小規模なスクレイピング。


4. プロキシ回転サービスを使用する

結論: 有料プロバイダは信頼性のあるランダムなIPを提供します。

手順:

  1. Luminati、ScraperAPI、またはScrapelessなどのサービスにサインアップします。
  2. APIキーを使用してエンドポイントを利用します。
python Copy
import requests

api_url = "https://proxyprovider.com?api_key=YOUR_KEY&url=https://example.com"
response = requests.get(api_url)
print(response.text)

アプリケーション: 手動でIP管理が不要な大規模なウェブスクレイピング。


5. Torを使用してランダムIPを生成する

結論: Torは匿名のランダムIPを提供します。

手順:

  1. Torとstemライブラリをインストールします。
  2. SOCKSプロキシ(127.0.0.1:9050)経由で接続します。
python Copy
proxies = {"http": "socks5h://127.0.0.1:9050", "https": "socks5h://127.0.0.1:9050"}
response = requests.get("https://example.com", proxies=proxies)

アプリケーション: 匿名スクレイピングや地域制限の回避。


6. SeleniumでランダムIPを使用する

結論: Seleniumはブラウザプロキシを介してIPを回転させることができます。

手順:

python Copy
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
import random

ips = ["111.111.111.111:8080", "222.222.222.222:8080"]
chrome_options = Options()
chrome_options.add_argument(f'--proxy-server={random.choice(ips)}')
driver = webdriver.Chrome(options=chrome_options)
driver.get("https://example.com")

アプリケーション: 複数のブラウザセッションを使用した自動化タスク。


7. HTTPXで非同期IP回転

結論: 非同期リクエストはランダムなIPで高い同時処理をサポートします。

python Copy
import httpx, asyncio, random

ips = ["111.111.111.111:8080", "222.222.222.222:8080"]

async def fetch(url):
    proxy = random.choice(ips)
    async with httpx.AsyncClient(proxies={"http": proxy, "https": proxy}) as client:
        r = await client.get(url)
        print(r.status_code)

asyncio.run(fetch("https://example.com"))

アプリケーション: 高速ウェブスクレイピング。


8. ScrapyでのIP回転

結論: Scrapyミドルウェアは自動的にランダムIPを割り当てることができます。

手順:

  1. HttpProxyMiddlewareを有効にします。
  2. settings.pyにプロキシのリストを定義します。
python Copy
DOWNLOADER_MIDDLEWARES = {'scrapy.downloadermiddlewares.httpproxy.HttpProxyMiddleware': 1}
PROXY_LIST = ['http://111.111.111.111:8080', 'http://222.222.222.222:8080']

アプリケーション: 多くのランダムIPを必要とする大規模なスパイダープロジェクト。


9. IP管理にScrapelessを使用

結論: ScrapelessはすべてのリクエストのためにランダムIPの割り当てを自動化します。

利点:

  • 手動IP管理を排除
  • 効率的に同時処理を処理
  • ブロックリスクを軽減

アプリケーション: 最小限のセットアップでのプロフェッショナルなスクレイピングに適しています。


10. 環境変数による動的IP

結論: 環境変数を使用して構成可能なランダムIPを提供します。

python Copy
import os, random
from dotenv import load_dotenv

load_dotenv()
ips = os.getenv("IPS").split(",")
random_ip = random.choice(ips)
print(random_ip)

アプリケーション: 様々なスクレイピングタスクのための柔軟なパイプラインセットアップ。


比較サマリー

方法 使いやすさ コスト スケーラビリティ 最適使用ケース
静的リスト 簡単 無料 小規模タスク
ランダム生成 簡単 無料 中程度 テスト
無料プロキシ 簡単 無料 中程度 低予算のスクレイピング
有料プロバイダー 簡単 有料 高い 大規模プロジェクト
Tor 中程度 無料 低い 匿名スクレイピング
Selenium 中程度 無料/有料 中程度 ブラウザ自動化
HTTPX Async 中程度 無料 高い 高い同時接続
Scrapy 中程度 無料 高い スパイダープロジェクト
Scrapeless とても簡単 有料 高い プロフェッショナルなスクレイピング
環境変数 中程度 無料 中程度 構成可能なパイプライン

主なポイント

  • ランダムIPはブロックを減少させ、スクレイピングの信頼性を向上させる。
  • Pythonは手動から自動まで、さまざまなアプローチをサポートしている。
  • Scrapelessは簡単で信頼性が高く、スケーラブルなソリューションを提供する。

FAQ

Q1: なぜランダムIPを生成するのか?
ブロックを防ぎ、一貫したスクレイピングのパフォーマンスを確保するため。

Q2: 無料IPリストを使用できますか?
はい、しかし安定性は限られています。大規模プロジェクトには有料ソリューションが推奨されます。

Q3: Scrapelessはコーディングが必要ですか?
最小限のコーディングが必要で、Pythonスクリプトとシームレスに統合されます。

Q4: SeleniumでIPを回転させることはできますか?
はい、ブラウザオプションでランダムプロキシを割り当てます。

Q5: どのくらいの頻度でIPを回転させるべきですか?
リクエストの量やターゲットサイトの制限によります。


推奨ソリューション

手間のかからない体験のために、Scrapelessを試して、ランダムIPを自動的に生成して回転させてみてください。


参考文献

Scrapelessでは、適用される法律、規制、およびWebサイトのプライバシーポリシーを厳密に遵守しながら、公開されているデータのみにアクセスします。 このブログのコンテンツは、デモンストレーションのみを目的としており、違法または侵害の活動は含まれません。 このブログまたはサードパーティのリンクからの情報の使用に対するすべての責任を保証せず、放棄します。 スクレイピング活動に従事する前に、法律顧問に相談し、ターゲットウェブサイトの利用規約を確認するか、必要な許可を取得してください。

最も人気のある記事

カタログ