这个计算器应该在网页文本框中输入带空格的输入(如“2 + 2”),然后回显上面的答案。目前,输出为“0”,或者它似乎会从输入中剪切一个随机数。
我95%确定问题在substr函数内 - 它们没有被分配正确的值。这是我的猜测,因为输出行为。为了演示,
1 + 1将= 0 2 + 2将= 0 ... 9 + 9将= 0 10 + 10将= 1 20 + 20将= 2
注意:从第16行开始的$ firstNumber,$ secondNumber和$运算符初始声明值是任意的。
以下是PHP手册中的 substr(,) 示例:
echo substr('abcdef', 1); // bcdef <br>
echo substr('abcdef', 1, 3); // bcd<br>
echo substr('abcdef', 0, 4); // abcd<br>
echo substr('abcdef', 0, 8); // abcdef<br>
echo substr('abcdef', -1, 1); // f<br>
。
//'if' is executed when submit is pressed
if (isset($_POST['test']))
{
$input = $_POST['test'];
$answer = calculate($input);
echo $answer;
}
//does string processing and number calculation
function calculate($input)
{
//declarations (random)
$firstNumber = 20;
$secondNumber = 30;
$operator = "+";
$answer = 7;
//string processing.
for($i = 0; $i <= strlen($input); $i++)
{
//if current position of the string scan is an operator,
if( trim(substr($input, $i, $i + 1), " ") == "+" ||trim(substr($input, $i, $i + 1), " ") == "-"
||trim(substr($input, $i, $i + 1), " ") == "*" ||trim(substr($input, $i, $i + 1), " ") == "/")
{
//then
//$operator = current position TO current position + 1
$operator = substr($input, $i, $i + 1);
//trim $operator
$operator = trim($operator, " ");
//$firstNumber = 0 TO current position - 1
$firstNumber = substr($input, 0, $i - 1);
//trim $operator
$firstNumber = trim($firstNumber, " ");
//$secondNumber = current position + 1 TO end of string
$secondNumber = substr($input, $i + 1, strlen($input));
//trim $operator
$secondNumber = trim($secondNumber, " ");
}
}
//if operator is ... then do that operation.
//example: if "+", then add $firstNumber and $secondNumber
if($operator == "+")
{
$answer = $firstNumber + $secondNumber;
}
else if($operator == "-")
{
$answer = $firstNumber - $secondNumber;
}
else if($operator == "*")
{
$answer = $firstNumber * $secondNumber;
}
else if($operator == "/")
{
$answer = $firstNumber / $secondNumber;
}
//return the calculated answer for echo
return $answer;
}
?>
<form action="test.php" method="POST">
<textarea name="test" rows="3" cols="30"></textarea>
<input type="submit" value="calculate!">
</form>
答案 0 :(得分:4)
您的问题是您使用substr
。
substr
取一个字符串,一个起始位置和一个长度。这是你滥用的长度。在平移输入字符串时,您将增加要查找的子字符串的长度。由于运算符的长度为1
,因此您应该使用
//if current position of the string scan is an operator,
if( trim(substr($input, $i, 1), " ") == "+" || trim(substr($input, $i, 1), " ") == "-"
||trim(substr($input, $i, 1), " ") == "*" || trim(substr($input, $i, 1), " ") == "/")
{
....
您还需要在此处更新您的代码:
//$operator = current position TO current position + 1
$operator = substr($input, $i, 1);
//trim $operator
$operator = trim($operator, " ");
你可以通过
来简化这一点 potentialOperator = trim(substr($input, $i, 1), " ")
并将其与您支持的运营商进行比较。这样可以节省多次不必要的trim
和substr
来电
这也意味着您只需识别一次操作员一次。
您可能还想查看preg_split
PREG_SPLIT_DELIM_CAPTURE
来解析输入字符串,而不是通过char扫描它。