有没有办法在字符串中查找子字符串的所有实例。这就是我到目前为止所看到的,但是当我搜索'ed'子串时,它会在找到第一个时停止查找。因此,当我试图改变结局时,“对冲”一词不受影响。
<?php
$wordList2 = array('kissed','hoped','learned','wanted','sounded', 'hedged');
for ($i = 0; $i<sizeof($wordList2);$i++){
$wrongAnswers2[$wordList2[$i]] = array();
}
for ($i = 0; $i < sizeof($wordList2); $i++){
if(strpos($wordList2[$i], 'ed')===(strlen($wordList2[$i])-2)) {
$pos = strpos($wordList2[$i], 'ed');
if(
substr($wordList2[$i], -3, 1) ==='p' ||
substr($wordList2[$i], -3, 1) ==='f' ||
substr($wordList2[$i], -3, 1) ==='s' ||
substr($wordList2[$i], -3, 1) ==='k' ||
substr($wordList2[$i], -3, 1) ==='h'
){
$replacement = substr_replace($wordList2[$i], 't', $pos,2);
array_push($wrongAnswers2[$wordList2[$i]],$replacement);
} else if
(
substr($wordList2[$i], -3, 1) ==='b' ||
substr($wordList2[$i], -3, 1) ==='v' ||
substr($wordList2[$i], -3, 1) ==='z' ||
substr($wordList2[$i], -3, 1) ==='g' ||
substr($wordList2[$i], -3, 1) ==='n'
){
$replacement = substr_replace($wordList2[$i], 'd', $pos,2);
array_push($wrongAnswers2[$wordList2[$i]],$replacement);
} else if
(
substr($wordList2[$i], -3, 1) ==='d' ||
substr($wordList2[$i], -3, 1) ==='t'
){
$replacement = substr_replace($wordList2[$i], 'id', $pos);
array_push($wrongAnswers2[$wordList2[$i]],$replacement);
}
}
}
?>
这是我得到的输出。我基本上想要一种方法来使程序改变'对冲'的结束。感谢。
Array
(
[kissed] => Array
(
[0] => kisst
)
[hoped] => Array
(
[0] => hopt
)
[learned] => Array
(
[0] => learnd
)
[wanted] => Array
(
[0] => wantid
)
[sounded] => Array
(
[0] => soundid
)
[hedged] => Array
(
)
)
答案 0 :(得分:1)
根据您的具体要求,您可以使用strrpos而不是strpos - 除了找到子串的最后一次出现而不是第一次出现之外,它是相同的。
答案 1 :(得分:0)
我刚改变了开场IF条件并调整了$ pos变量:
if((strlen($wordList2[$i]) - strrpos($wordList2[$i], 'ed'))===2) {
$pos = strrpos($wordList2[$i], 'ed');
...etc.
现在好多了,谢谢moopet。