3

我正在为我们的网站做大量用户检查,下面是代码。如果只有 1 个帐户,我如何使用“用户”一词,如果有 >1,我如何使用“用户”。

代码:

       $result = mysql_query("SELECT * FROM users WHERE user_id='$userid'");
       $num_rows = mysql_num_rows($result);

        echo "amount of users.";
4

4 回答 4

9

所有这些答案都可以很好地工作,但是如果您正在寻找一种可重用的方式,您可以随时将其外部化:

function get_plural($value, $singular, $plural){
    if($value == 1){
        return $singular;
    } else {
        return $plural;
    }
}

$value = 0;
echo get_plural($value, 'user', 'users');

$value = 3;
echo get_plural($value, 'user', 'users');

$value = 1;
echo get_plural($value, 'user', 'users');

// And with other words
$value = 5;
echo get_plural($value, 'foot', 'feet');

$value = 1;
echo get_plural($value, 'car', 'cars');

或者,如果您希望它更加自动化,您可以将其设置为仅$plural在它是替代词时需要变量集(例如:foot/feet):

function get_plural($value, $singular, $plural = NULL){
    if($value == 1){
        return $singular;
    } else {
        if(!isset($plural)){
            $plural = $singular.'s';
        }
        return $plural;
    }
}

echo get_plural(4, 'car');   // Outputs 'cars'
echo get_plural(4, 'foot');  // Outputs 'foots'
echo get_plural(4, 'foot', 'feet');  // Outputs 'feet'
于 2011-02-21T14:29:39.890 回答
6

也许我弄错了,但很明显:

echo $num_rows > 1 ? 'users' : 'user';
于 2011-02-21T14:16:42.037 回答
4

尝试

if($num_rows === 1)
{
    echo "user";
}
else
{
    echo "users";
}

或简称

echo $num_rows === 1 ? "user" : "users";
于 2011-02-21T14:16:25.883 回答
4
if ($num_rows === 1) {
    echo "a user.";
}
else if ($num_rows > 1) {
    echo "amount of users.";
}
else {
    echo "no users".
}
于 2011-02-21T14:16:57.247 回答