私はURLが入っている文字列がたくさんあるので、URLを削除して別のものに置き換える必要があります。私はそれを行うに考えることができる唯一の方法は、split
である:URLを文字列に置き換える - Perl
($start, $url, $end) = split(/:/);
しかし、URLが文字列の先頭や末尾にある場合ので、私は、これはそれについて移動する正しい方法だとは思いません正しく動作しません。
任意のアイデアは大歓迎:)
私はURLが入っている文字列がたくさんあるので、URLを削除して別のものに置き換える必要があります。私はそれを行うに考えることができる唯一の方法は、split
である:URLを文字列に置き換える - Perl
($start, $url, $end) = split(/:/);
しかし、URLが文字列の先頭や末尾にある場合ので、私は、これはそれについて移動する正しい方法だとは思いません正しく動作しません。
任意のアイデアは大歓迎:)
URI::URLはあなたの友達です。
#!/usr/bin/perl
use strict;
use URI::Split qw(uri_split uri_join);
my ($scheme, $auth, $path, $query, $frag) = uri_split($uri);
my $uri = uri_join($scheme, $auth, $path, $query, $frag);
URI :: SplitはURLをコンポーネントの部分に分割するためのものであり、他のテキストも含む文字列のURLを見つけるためのものではありません。 – cjm
OPは他のテキストの中にURLを見つけようとしていません。元の質問には、「URLが入った文字列がたくさんある」ということだけが記載されています。与えられた例でさえ '分割'を使用しています。さて、私は問題が実際には2つの問題であることに同意します。 –
URI::Findをお試しください。
すでに提案されているURI::Findは良い賭けに見えます。
あるいは、Regexp::Commonは、例えば、URLを一致させるために適切なURLを提供することができる:
use Regexp::Common qw(URI);
my $string = "Some text, http://www.google.com/search?q=foo and http://www.twitter.com/";
$string =~ s{$RE{URI}}{http://stackoverflow.com/}g;
上記の例としてhttp://stackoverflow.com/
と両方のURLを置き換えることになります。
あなたはまた、複数の入力ファイルがある、と一貫してすべての入力ファイル内の文字列を変更する必要がある場合、このスクリプトは便利になることができます。
は、あなたがしたいものの例のカップルを供給できますストリングとは? – Tim