|
|
|
| Есть файл:
1*8*5*9
2*3*7*3
3*7*0*1
Если я хочу отсортировать по третьему столбу, то должен получить:
3*7*0*1
1*8*5*9
2*3*7*3
Если по второму:
2*3*7*3
3*7*0*1
1*8*5*9
Иными словами - соответствия строк должны сохраняться. Как это делается? | |
|
|
|
|
|
|
|
для: Shorr Kan
(09.03.2006 в 10:48)
| | Есть функция uasort() которая способна Вам помочь! Смысл функции в том, что вы сами пишите функцию сравнения для сортировки и тем самым можите сортировать сложные структуры по разным критериям.
Делаеться это так. Сначала нужно написать функцию которая будет сравнивать Ваши две строки так, как вам этого хочеться (Например по третьему числу). Если результат "больше", функция должна вернуть 1, если "меньше", то -1. Ну а если "равно" то соответственно 0. В вашем случае это будет выглядить так:
<?
// $str1, $str2 - сравниваемые строки
// $n - номер елемента покоторому произойдет сортировка (нач. с нуля)
function cmp_func($str1, $str2, $n) {
$n = 3;
// разбиваем строку, передавая еечасти разделенные * в массив
$arr1 = explode("*", $str1);
$arr2 = explode("*", $str2);
//ну а теперь сравниваем
if ( $arr1[$n] > $arr2[$n] ) return 1;
if ( $arr1[$n] == $arr2[$n] ) return 0;
if ( $arr1[$n] < $arr2[$n] ) return -1;
}
?>
|
Теперь можно приступать к сортировке.
<?
/*$fstr - предположим в эту строку вы считали из файла
и она содержит что то вроде
1*8*5*9
2*3*7*3
3*7*0*1
*/
$arr = explode("\n", $fstr);
uasort($arr, "cmp_func");
/* в результате в массиве $arr окажуться строки в таком порядке:
3*7*0*1
1*8*5*9
2*3*7*3
Внимание! Индексы массива не меняються, а лишь меняется порядок элементов!
*/
?>
|
| |
|
|
|
|
|
|
|
для: Temnovit
(09.03.2006 в 11:58)
| | Вроде бы сработало, но она отсортировала так:
0
1
1
113
2
21
24
3
Т.е., только по первому символу... | |
|
|
|
|
|
|
|
для: Shorr Kan
(09.03.2006 в 14:06)
| | Понятно. Не хватало обрезания пробелов в конце. Работает, спасибо. | |
|
|
|
|
|
|
|
для: Shorr Kan
(09.03.2006 в 16:14)
| | а попробуйте данные "насильно" привести к числовому типу: сейчас сравниваются строки. | |
|
|
|