gpt4 book ai didi

php - array_multisort - 不对我的完整表格进行排序

转载 作者:行者123 更新时间:2023-11-29 02:54:11 26 4
gpt4 key购买 nike

我第一次尝试使用 array_multisort 函数,但它没有像我预期的那样工作。我真的希望有人能帮助我。这是我的问题:

我确实有一个包含 7 列的表格。我想通过单击列名对其中的 4 个进行排序。我的问题是排序过程总是只适用于一列。让我解释一下我的意思。这是我要排序的 4 列:

Points | Name | Leader | Owner
10 | Chris | Thomas | Philip
0 | Alex | Sandy | Oscar
5 | David | Lucas | Kathi

现在使用我的代码,例如,当我单击“名称”时,我的表格将按如下方式排序:

Points | Name | Leader | Owner
10 | Alex | Thomas | Philip
0 | Chris | Sandy | Oscar
5 | David | Lucas | Kathi

例如,当我点击“所有者”时,我的表格如下所示:

Points | Name | Leader | Owner
10 | Chris | Thomas | Kathi
0 | Alex | Sandy | Oscar
5 | David | Lucas | Philip

如您所见,只有我单击的列会按字母顺序排序,而不是整个表格。那不是我需要的。

整个表格应该被排序,作为一个例子,它应该是这样的。当我点击“Leader”时,完整的表格应该像这样排序:

Points | Name | Leader | Owner
5 | David | Lucas | Kathi
0 | Alex | Sandy | Oscar
10 | Chris | Thomas | Philip

这是我的代码。注意:一切正常,这只是我完整代码的一部分,但我希望有人能告诉我我到底做错了什么以及我的代码应该是什么样子,以便对整个表格进行排序。

<form name='form1' action='./index.php' method='post'>
<input type='hidden' name='func' value='".$func."'>
<input type='hidden' name='submenu' value='".$submenu."'>
<input type='hidden' name='id' value='".$id."'>
<input type='hidden' name='module_id' value='".$module_id."'>
<input type='hidden' name='save_data' value='true'>
<input type='hidden' name='sort' value='".$sort."'>
<input type='hidden' name='sid' value='".$sid."'>

<br><table>
<tr>
<td>P</td>
<td>L</td>
<td>E</td>
<td>O</td>
<td><a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=attendance_points&sid=$sid'>Points</a></td>
<td><a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=student_name&sid=$sid'>Student</a></td>
<td><a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=leader_name&sid=$sid'>Leader</a> | <a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=owner_name&sid=$sid'>Owner</a></td>
</tr>

<?php
$output=array();

if ($sort=="") { $sort="student_name"; }
array_multisort($output[$sort], SORT_ASC, SORT_STRING);

for ($x=0;$x<count($output["id"]);$x++) {
$attendance=getUserModuleAttendanceInfo($output["pers_id"][$x],$id,$module_id);

print "<tr>";
if (count($attendance["id"])==0) {
print "<td align='center'><input type='checkbox' name='part_1_".$output["pers_id"][$x]."' value='1'></td>";
print "<td align='center'><input type='checkbox' name='part_2_".$output["pers_id"][$x]."' value='1'></td>";
print "<td align='center'><input type='checkbox' name='part_3_".$output["pers_id"][$x]."' value='1'></td>";
print "<td align='center'><input type='checkbox' name='part_4_".$output["pers_id"][$x]."' value='1'></td>";

if($output["edit_coursepoints"][$x]==0) {
print "<td align='center'><input type='hidden' name='points_".$output["pers_id"][$x]."' id='spinner_".$output["pers_id"][$x]."' value='".$module["points_present"][0]."'></td>";
}
else {
print "<td align='center'><input type='text' name='points_".$output["pers_id"][$x]."' id='spinner_".$output["pers_id"][$x]."' value='".$module["points_present"][0]."'></td>";
}
$controller_list.="spinner_".$output["pers_id"][$x].";";
} else {
print "<td colspan='4' valign='center' align='center'><span class='label label-".$course_part_state["style"][$attendance["part_state"][0]]."'><i class='ace-icon fa fa-".$course_part_state["icon"][$attendance["part_state"][0]]." bigger-120'></i> ".strtoupper($course_part_state["txt"][$attendance["part_state"][0]])."</span></td>";
print "<td align='center'>".$attendance["part_points"][0]."</td>";
}


print "<td>".$staffshort[$student["grade"][0]]." ".$output["student_name"][$x]."</td>";
print "<td>leader: ".$staffshort[$leader["grade"][0]]." ".$output["leader_name"][$x]."<br>owner: ".$staffshort[$owner["grade"][0]]." ".$output["owner_name"][$x]."</td>";
if (count($attendance["id"])>0) {
print "<td align='center'><a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=$sort&undo=".$attendance["id"][0]."&sid=$sid'><i class='ace-icon fa fa-undo dark bigger-180'></i></a></td>";
}
print "</tr>";
}
?>

希望有人能告诉我我做错了什么!

最佳答案

我建议重新组织您的$output。现在,每个 字段都有一个单独的数组。这很难处理。

如果您让 $output 中的每一行都是一个具有自己的键/值对的表行,将会更容易。

所以,试着像这样构建它:

$output[] = array(
"id" => $data["id"][$x],
"pers_id" => $student["pers_id"][0],
"student_name" => $student["firstname"][0]." ".strtoupper($student["lastname"][0]),
"owner" => $owner["pers_id"][0],
"owner_name" => $owner["firstname"][0]." ".strtoupper($owner["lastname"][0]),
"leader" => $leader["pers_id"][0],
"leader_name" => $leader["firstname"][0]." ".strtoupper($leader["lastname"][0]),
"edit_coursepoints" => $editcoursepoints,
"attendance_points" => $attendance["part_points"][0]
);

然后您可以使用 usort 对其进行排序:

usort($output, function($a, $b) use($sort){
return strcmp($a[$sort], $b[$sort]);
});

然后当您构建表格时,您只需遍历 $output 中的每一行并打印出值。

foreach($output as $row){
echo '<tr>';

echo "<td align='center'><input type='checkbox' name='part_1_".$row["pers_id"]."' value='1'></td>";

echo '</tr>';
}

关于php - array_multisort - 不对我的完整表格进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32571679/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com