文字列を検索するときに、針の配列にstrpos
をどのように使用しますか?例えば:
$find_letters = array('a', 'c', 'd');
$string = 'abcdefg';
if(strpos($string, $find_letters) !== false)
{
echo 'All the letters are found in the string!';
}
これを使用するとき、それは機能しないので、このようなものがあれば良いでしょう
@Daveから http://www.php.net/manual/en/function.strpos.php#107351 の更新されたスニペット
function strposa($haystack, $needles=array(), $offset=0) {
$chr = array();
foreach($needles as $needle) {
$res = strpos($haystack, $needle, $offset);
if ($res !== false) $chr[$needle] = $res;
}
if(empty($chr)) return false;
return min($chr);
}
使い方:
$string = 'Whis string contains Word "cheese" and "tea".';
$array = array('burger', 'melon', 'cheese', 'milk');
if (strposa($string, $array, 1)) {
echo 'true';
} else {
echo 'false';
}
true
"cheese"
のため、array
を返します。
更新:最初の針が見つかったときに停止するコードを改善しました:
function strposa($haystack, $needle, $offset=0) {
if(!is_array($needle)) $needle = array($needle);
foreach($needle as $query) {
if(strpos($haystack, $query, $offset) !== false) return true; // stop on first true result
}
return false;
}
$string = 'Whis string contains Word "cheese" and "tea".';
$array = array('burger', 'melon', 'cheese', 'milk');
var_dump(strposa($string, $array)); // will return true, since "cheese" has been found
str_replaceはかなり高速です。
$find_letters = array('a', 'c', 'd');
$string = 'abcdefg';
$match = (str_replace($find_letters, '', $string) != $string);
以下のコードは、それを行う方法を示すだけでなく、使いやすい関数に進んでいます。それは「ジェスダ」によって書かれました。 (オンラインで見つけた)
PHPコード:
<?php
/* strpos that takes an array of values to match against a string
* note the stupid argument order (to match strpos)
*/
function strpos_arr($haystack, $needle) {
if(!is_array($needle)) $needle = array($needle);
foreach($needle as $what) {
if(($pos = strpos($haystack, $what))!==false) return $pos;
}
return false;
}
?>
使用法:
$needle = array('something','nothing');
$haystack = "This is something";
echo strpos_arr($haystack, $needle); // Will echo True
$haystack = "This isn't anything";
echo strpos_arr($haystack, $needle); // Will echo False
strpos
がfalse
を返す場合、配列を反復処理し、「フラグ」値を設定できます。
$flag = false;
foreach ($find_letters as $letter)
{
if (strpos($string, $letter) === false)
{
$flag = true;
}
}
次に、$flag
の値を確認します。
特定の文字が実際に文字列に含まれているかどうかを確認するだけの場合は、 strtok を使用します。
$string = 'abcdefg';
if (strtok($string, 'acd') === $string) {
// not found
} else {
// found
}
この式はすべての文字を検索します。
count(array_filter(
array_map("strpos", array_fill(0, count($letters), $str), $letters),
"is_int")) == count($letters)
質問、提供された例は単なる「例」ですか、それともあなたが探しているものですか?ここには多くの複雑な答えがあり、受け入れられたものの複雑さを理解していません。
ANY針の配列のコンテンツが文字列に存在するかどうか、およびquicklytrueまたはfalseを返します:
$string = 'abcdefg';
if(str_replace(array('a', 'c', 'd'), '', $string) != $string){
echo 'at least one of the needles where found';
};
もしそうなら、 @ Leon のクレジットを与えてください。
ALL針の配列の値が文字列に存在するかどうかを調べるには、この場合、3つの'a', 'b'
と'c'
がすべて存在する必要があります。たとえば、「たとえば」としてを挙げます
echo 'すべての文字が文字列にあります!';
ここでの多くの回答はその文脈から外れていますが、あなたが解決したとマークした質問の意図は疑わしいです。例えば。受け入れられた答えは
$array = array('burger', 'melon', 'cheese', 'milk');
これらのすべての単語が文字列内になければならない場合はどうなりますか?
次に、このページでいくつかの"not accepted answers"
を試してください。
これを試すことができます:
function in_array_strpos($Word, $array){
foreach($array as $a){
if (strpos($Word,$a) !== false) {
return true;
}
}
return false;
}
これが私のアプローチです。一致が見つかるまで、文字列内の文字を繰り返し処理します。より大きな針の配列では、一致が見つかったことを判断するためにすべての針をチェックする必要がないため、これは受け入れられた答えよりも優れています。
function strpos_array($haystack, $needles = [], $offset = 0) {
for ($i = $offset, $len = strlen($haystack); $i < $len; $i++){
if (in_array($haystack[$i],$needles)) {
return $i;
}
}
return false;
}
私はこれを受け入れられた答えに対してベンチマークし、7 $needles
の配列で劇的により高速でした。
また、否定に strpbrk() を使用してみることもできます(文字が見つかりませんでした)。
$find_letters = array('a', 'c', 'd');
$string = 'abcdefg';
if(strpbrk($string, implode($find_letters)) === false)
{
echo 'None of these letters are found in the string!';
}
@binyaminと@Timo ..に返信します(コメントを追加するのに十分なポイントではありません)。しかし、結果には位置が含まれていません。
以下のコードは、strposが意図している最初の要素の実際の位置を返します。これは、正確に1つの一致を見つけることを期待している場合に役立ちます。複数の一致を見つけることを期待している場合、最初に見つかった位置は意味がない場合があります。
function strposa($haystack, $needle, $offset=0) {
if(!is_array($needle)) $needle = array($needle);
foreach($needle as $query) {
$res=strpos($haystack, $query, $offset);
if($res !== false) return $res; // stop on first true result
}
return false;
}
上記の答えからアップグレードするだけです
function strsearch($findme, $source){
if(is_array($findme)){
if(str_replace($findme, '', $source) != $source){
return true;
}
}else{
if(strpos($source,$findme)){
return true;
}
}
return false;
}
次のコードで:
$flag = true;
foreach($find_letters as $letter)
if(false===strpos($string, $letter)) {
$flag = false;
break;
}
次に、$flag
の値を確認します。 true
の場合、すべての文字が見つかりました。そうでない場合は、false
です。
私は、私と同じようなものを探している人に役立つ新しい答えを書いています。
これは、「複数の針があり、それらを使用してシングルアウト文字列を見つけようとしている」場合に機能します。これが私が見つけた質問です。
$i = 0;
$found = array();
while ($i < count($needle)) {
$x = 0;
while ($x < count($haystack)) {
if (strpos($haystack[$x], $needle[$i]) !== false) {
array_Push($found, $haystack[$x]);
}
$x++;
}
$i++;
}
$found = array_count_values($found);
配列$found
には、一致するすべての針のリストが含まれます。最高のカウント値を持つ配列の項目は、探している文字列になります。これは次のようにして取得できます。
print_r(array_search(max($found), $found));