按数字值排序文本数据

时间:2011-07-11 20:36:21

标签: php forms sorting

我有一个模拟幻想足球形式,在外部文本文件中创建数据,我有一切正常,我刚遇到一个问题。有人可以告诉我如何根据他们的数量(最大的顶部)对球员进行排序,然后突出(以红色表示)得分最多的球员的整行?

这是我的表单文件:

<!doctype html public "-//W3C//DTD HTML 4.0 //EN">
<html>
<head>

<title>Fantasy Football</title>
</head>
<body>
<form action="team.php" method="POST">
<table border="1">
<tr><td>Player Name</td><td><input type="text" name="name"</td></tr>
<tr><td>Position</td><td><input type="text" name="position"</td></tr>
<tr><td>Number</td><td><input type="text" name="number"</td></tr>
<tr><td>Team</td><td><input type="text" name="team"</td></tr>
<tr><td>Points per game</td><td><input type="text" name="points"</td></tr>
<tr><td colspan="2" align="center"><input type="submit"></td></tr>
</table>
</form>
</body>
</html>

以下是返回数据:

<?php
$name = $_POST['name'];
$team = $_POST['team'];
$number = $_POST['number'];
$position = $_POST['position'];
$points = $_POST['points'];
$DOC_ROOT = $_SERVER['DOCUMENT_ROOT'];

@ $fp = fopen("$DOC_ROOT/../php/football.txt","ab");

if(!$fp) {
echo 'Error: Cannot open file.';
exit;
} 

fwrite($fp, $name."|".$team."|".$number."|".$position."|".$points."\n");
?>

<?php
$DOC_ROOT = $_SERVER['DOCUMENT_ROOT'];
$players = file("$DOC_ROOT/../php/football.txt");
echo "<table border='2'>";
echo "<tr> <td>Name</td> <td>Team</td> <td>number</td> <td>Position</td> <td>Points</td> </tr>";
for($i = 0; $i < sizeof($players); $i++) {
list($name,$team,$number,$position,$points) = explode('|', $players[$i]);
 echo '<tr><td>'.$name.'</td><td>'.$team.'</td><td>'.$number.'</td>
 <td>'.$position.'</td><td>'.$points.'</td></tr>';
 }
 echo '</table>';
 ?>

不是很擅长插入一些代码,所以如果可以的话,你能告诉我确切地说你可以给我什么吗?

更新

这是我需要放置一切的地方吗?现在的样子,当我提交表格时,我看不到任何东西!显然我做错了,所以我愿意接受建议!

    <?php
function sort_player_array( $array, $key, $asc = true) {
$result = array();

$values = array();
foreach ($array as $id => $value) {
    $values[$id] = isset($value[$key]) ? $value[$key] : '';
}

if ($asc) {
    asort($values);
}
else {
arsort($values);
}

foreach ($values as $key => $value) {
    $result[$key] = $array[$key];
}

return $result;
}
?>
<?php
$name = $_POST['name'];
$team = $_POST['team'];
$number = $_POST['number'];
$position = $_POST['position'];
$points = $_POST['points'];
$DOC_ROOT = $_SERVER['DOCUMENT_ROOT'];

@ $fp = fopen("$DOC_ROOT/../php/football.txt","ab");

if(!$fp) {
echo 'Error: Cannot open file.';
exit;
}
?>
<?php
fwrite($fp, $name."|".$team."|".$number."|".$position."|".$points."\n");

$players = file("$DOC_ROOT/../php/football.txt");
$player_array = array();

foreach($players AS $player)
{
list($name,$team,$number,$position,$points) = explode('|', $players[$i]);
$player_array[] = array('name'     => $name,
                        'number'   => $number,
                        'position' => $position,
                        'points'   => $points,
);
}

$sorted_players = sort_player_array($player_array, 'number', true);

foreach( $sorted_players AS $player )
{
echo '<tr><td>'.$player[name].'</td><td>'.$player[team].'</td><td>'
.$player[number].'</td><td>'.$player[position].'</td><td>'.$player[points].'</td></tr>';
} ?>

4 个答案:

答案 0 :(得分:1)

首先,您使用PHP编程,使用COUNT()而不是SIZEOF()。 sizeof()是count()的别名,可能会随着php的发展而被删除。

我们需要一个用于对数组进行排序的函数:

function sort_player_array( $array, $key, $asc = true) {
    $result = array();

    $values = array();
    foreach ($array as $id => $value) {
        $values[$id] = isset($value[$key]) ? $value[$key] : '';
    }

    if ($asc) {
        asort($values);
    }
    else {
    arsort($values);
    }

    foreach ($values as $key => $value) {
        $result[$key] = $array[$key];
    }

    return $result;
}

接下来使用php保存数据构建一个数组,然后对其进行排序。

$players = file("$DOC_ROOT/../php/football.txt");
$player_array = array();

foreach($players AS $player)
{
    list($name,$team,$number,$position,$points) = explode('|', $players[$i]);
    $player_array[] = array('name'     => $name,
                            'number'   => $number,
                            'position' => $position,
                            'points'   => $points,
    );
}

我们按照您的号码要求对数组进行排序,但任何键都是可能的。您也可以使用第三个变量

设置ASC或DESC
$sorted_players = sort_player_array($player_array, 'number', true);

foreach( $sorted_players AS $player )
{
    echo '<tr><td>'.$player[name].'</td><td>'.$player[team].'</td><td>'.$player[number].'</td><td>'.$player[position].'</td><td>'.$player[points].'</td></tr>';
}

答案 1 :(得分:0)

好像你需要$players的某种排序算法功能。有各种各样的,你可以通过谷歌搜索“排序算法”找到许多,或者你可以自己写一个如果你想“重新发明轮子”。自己做一个确实有益于实践/乐趣:D

Here's a link一个关于冒泡排序的维基,可能是最常见的基本排序,对你的情况有帮助。

答案 2 :(得分:0)

准备一个数组$playerData,其中包含所有玩家记录并使用其数字作为关键字。然后使用ksort()

ksort( $playerData );

在准备$playerData时,保留一个变量$ maxPoints和$ mapPointsPlayerNumber,并根据这些值检查每个玩家的数据。如果当前玩家的积分高于$ maxPoints,则更新它们。

答案 3 :(得分:0)

我认为您应该能够使用list函数创建数组。像这样:

    //set array variables
    for($i = 0; $i < sizeof($players); $i++) {
    list($name[],$team[],$number[],$position[],$points[]) = explode('|', $players[$i]);
     }
//sort all arrays by the number, in descending order
array_multisort($number, $position, $name, $team, $points, SORT_DESC);
//set the highest points to mostPoints variable
var mostPoints = max($points);
    //Output table rows
    for($i = 0; $i < sizeof($players); $i++) {
    if($points[$i]==mostPoints){
        //red background
        echo '<tr style="background:#F44">';
}else{
        echo '<tr>';
}
echo '<td>'.$name[$i].'</td><td>'.$team[$i].'</td><td>'.$number[$i].'</td><td>'.$position[$i].'</td><td>'.$points[$i].'</td></tr>';
    }

我没有对此进行过测试,所以我可能会错过一些内容,但它应该可行。请参阅Array Multisortmax功能。将类分配给红色表行而不是样式可能更好;这样你可以改变td标签;我认为这更适合浏览器。如果你给.redRow td {background:#F44} trredRow,那么CSS就像{{1}}。