嗨,我正在努力做到这一点:
我想比较两个字符串并以 php 计算它们的分数。
这意味着我有两个字符串:
$string 1="示例1";$string 2="exumple22";
现在我想比较字符串是否相等 - 在这种情况下它们不是。
但另外,我想看到匹配的角色。至少数一数。
在这种情况下,这将是:6;
我已经尝试过这个,但我被卡住了,她就是我的例子:
enter code here
<?
include("connect.php");
$query="SELECT * FROM data where ID = '1'";
$result = mysql_query($query) or die(mysql_error());
while($row = mysql_fetch_array($result))
{
//echo "Score :{$row['scoreA']} <br>" ;
$scoretemp=$row['scoreA'];
$string1=$row['textA1'];
$string2=$row['textA2'];
}
mysql_close();
if (strcmp($string1, $string2) != 0){
echo "not equal in a case-sensitive string comparison <br>";
$j = strlen($string1);
for ($i = 0; $i < $j; $i++) {
$stringtemp1++;
echo $string1[$i].', ';
echo $stringtemp1;
}
$u = strlen($string2);
for ($t = 0; $t < $u; $t++) {
$stringtemp2++;
echo $string2[$t].', ';
echo $stringtemp2;
}$scoreA=($stringtemp1 - $stringtemp2);
$stringtemp1=0;$stringtemp2=0;
}
else{
echo "Stringmatch! <br>";
$e = strlen($string1);
for ($r = 0; $r < $e; $r++) {
$stringtemp1++;
echo $string1[$r].', ';
echo $stringtemp1;
}$scoreA=$stringtemp1;
$stringtemp1=0;
}
?>
请参阅 http://www.php.net/manual/en/function.similar-text.php 了解如何使用similar_text($str1, $str2)
这将为您提供两个字符串中匹配字符的数量。
<?php
echo similar_text("Hello World","Hello Peter");
?>
会给你 7(共同的字符数)。
试试这个
<?php
$string1 = 'example1';
$string2 = 'exumple22';
$matchingcharacters = [];
$mismatchingcharacters = [];
$len1 = strlen($string1);
$len2 = strlen($string2);
$similarity = $i = $j = $dissimilarity = 0;
while (($i < $len1) && isset($string2[$j])) {
if ($string1[$i] == $string2[$j]) {
$similarity++;
$matchingcharacters[] = '['.$string1[$i].']';
} else {
$dissimilarity++;
$mismatchingcharacters[] = '['.$string1[$i] . " & " . $string2[$j].']';
}
$i++;
$j++;
}
echo 'First string : '.$string1.'<br>';
echo 'Second string : '.$string2.'<br>';
echo 'Similarity : ' . $similarity . '<br>';
echo 'Dissimilarity : ' . $dissimilarity . '<br>';
echo 'Matching characters : ' . implode(",", $matchingcharacters) . '<br>';
echo 'Mismatching characters : ' . implode(",", $mismatchingcharacters);
您可以计算 2 个字符串之间的 levenshtein 距离:
在最简单的形式中,该函数将仅将两个字符串作为参数,并且仅计算将 str1 转换为 str2 所需的插入、替换和删除操作的数量。