/** * ドメイン非依存URL出力フィルタ * javadrill.tech移行時はwp_options.home/siteurlのみ変更すればよい * * データベースには絶対URL(https://minner.asia)を保持し、 * 表示時に現在のドメイン(home_url())に動的変換する */ function javadrill_make_urls_dynamic($content) { if (empty($content)) { return $content; } // データベース内の絶対URLを現在のhome_url()に置換 $old_url = 'https://minner.asia'; $new_url = untrailingslashit(home_url()); // http版も対応(念のため) $content = str_replace($old_url, $new_url, $content); $content = str_replace('http://minner.asia', $new_url, $content); return $content; } // 投稿本文、ウィジェット、タームの説明、抜粋に適用 add_filter('the_content', 'javadrill_make_urls_dynamic', 20); add_filter('widget_text', 'javadrill_make_urls_dynamic', 20); add_filter('term_description', 'javadrill_make_urls_dynamic', 20); add_filter('get_the_excerpt', 'javadrill_make_urls_dynamic', 20); 013 クラスライブラリ(正規表現のパターンを扱うクラス) 019 問題 | Javaドリル

013 クラスライブラリ(正規表現のパターンを扱うクラス) 019 問題

013-019 013 クラスライブラリ

問題

与えられたテキストからURLを抽出するプログラムを書いてください。

ヒント

  1. 正規表現の使用:
    • URLは一般的に特定のパターンに従います。正規表現を使用してこれらのパターンを特定し、URLを抽出します。
  2. URLの一般的なパターン:
    • URLの一般的な形式は http(s)://www.example.com のようになっています。これにマッチする正規表現を作成します。ただし、URLの形式は多岐にわたるので、用途によって適切な正規表現を選択する必要があります。
  3. 正規表現のテスト:
    • 正規表現をテストするために、いくつかのサンプルテキストを用意しておくと良いです。例えば、HTMLのソースコードからURLを抽出する場合は、HTMLソースの一部を使用してテストすると良いでしょう。
  4. グループ化:
    • URLにはプロトコル、ホスト、パスなどがあります。これらの部分を正確に抽出するために、正規表現内でグループ化を使用すると便利です。例えば、(http://)(www\\.)?(example\\.com) のようにグループを作成します。
  5. Matcherクラスの利用:
    • Pattern クラスで正規表現をコンパイルし、Matcher クラスを使用してテキストと一致させます。find() メソッドを使用して一致を見つけ、group() メソッドでグループを取得します。
  6. 重複を防ぐ:
    • 同じURLが複数回出現する可能性がある場合は、重複を防ぐ仕組みを考慮すると良いです。

これらのヒントを考慮して、特定のテキストからURLを抽出するための正規表現を作成し、Javaの正規表現機能を使用してプログラムを実装してみてください。

→解答例

「013 クラスライブラリ」問題集リスト

🎯 実習で理解を深めよう

この内容についてJavaDrillで実際に手を動かして学習できます

コメント

タイトルとURLをコピーしました