我有一些与彼此有关的实体。
Answer
- AnswerGroup
AnswerGroup
Condition
- Question
Notion
Question
- AnswerGroup
- Theme
- Notion
ThemePhp表示:
$entities = [
['name' => 'Answer', 'relations' => ['AnswerGroup']],
['name' => 'AnswerGroup', 'relations' => []],
['name' => 'Condition', 'relations' => ['Question']],
['name' => 'Notion', 'relations' => []],
['name' => 'Question', 'relations' => ['Theme', 'AnswerGroup', 'Notion']],
['name' => 'Theme', 'relations' => []],
];我需要对它们进行排序,以便将依赖项放在第一位。以下是我期待的结果:
array:6 [
0 => "AnswerGroup"
1 => "Answer"
2 => "Notion"
3 => "Theme"
4 => "Question"
5 => "Condition"
]我很天真,虽然我可以像这样简单地使用usort
usort($entities, function ($entityA, $entityB) {
if (in_array($entityB, $entityA['relations'])) {
return 1;
}
if (in_array($entityA, $entityB['relations'])) {
return -1;
}
return 0;
});但是:
dump(array_column($entities ,'name'));给出
array:6 [
0 => "Answer"
1 => "AnswerGroup"
2 => "Condition"
3 => "Notion"
4 => "Question"
5 => "Theme"
]我怎样才能订购我的实体?
发布于 2019-01-02 11:43:08
这是做你想做的事的一种方式。它使用一个递归函数列出每个实体的所有依赖项(关系)。每个实体的关系列表在处理前进行排序,以便按字母顺序得到每个级别关系的结果。最后,array_unique用于删除重复条目(例如,AnswerGroup是Answer和Question的关系)。
function list_dependents($entity, $entities) {
$sorted = array();
sort($entity['relations']);
foreach ($entity['relations'] as $r) {
$sorted = array_merge($sorted, list_dependents($entities[array_search($r, array_column($entities, 'name'))], $entities));
}
$sorted = array_merge($sorted, array($entity['name']));
return $sorted;
}
$sorted = array();
foreach ($entities as $entity) {
$sorted = array_merge($sorted, list_dependents($entity, $entities));
}
$sorted = array_values(array_unique($sorted));
print_r($sorted);输出:
Array (
[0] => AnswerGroup
[1] => Answer
[2] => Notion
[3] => Theme
[4] => Question
[5] => Condition
)https://stackoverflow.com/questions/54004930
复制相似问题