为什么我的PHP计算器不工作? (字符串函数..)

时间:2012-08-01 17:30:44

标签: php html

这个计算器应该在网页文本框中输入带空格的输入(如“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>

1 个答案:

答案 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), " ")

并将其与您支持的运营商进行比较。这样可以节省多次不必要的trimsubstr来电 这也意味着您只需识别一次操作员一次。

您可能还想查看preg_split PREG_SPLIT_DELIM_CAPTURE来解析输入字符串,而不是通过char扫描它。