Forum Webscript.Ru
Программирование => PHP => Тема начата: Jeka от 04 Июля 2004, 19:22:24
-
Чтобы не плодить новых веток, хотелось бы поднять эту старую...
Мой вопрос: если большой массив хранится в отдельном файле, как его проинициализировать в скрипте, т.е. занести в переменную, чтобы в дальнейшем из этого скрипта можно было работать с этим массивом?
Можно конечно в файле заключить содержимое массива в ?>, а в скрипте использовать include(\'massiv.dat\'); а если по-другому, то как?
-
не надо поднимать ископаемые ветки.
а открывать новые темы совсем не так страшно, как тебе кажется.
вариантов хранить массив в файле - масса.
что у тебя за массив и что в нем лежит?
-
Лежит двухмерный массив. Записываю каждую новую строчку в конец файла, завершаю символом конца строки, например вот так:
$result="\\$arr[]=array(1=>\'$name\',2=>\'$url\',3=>\'$mail\',4=>\'$menu\',5=>\'$descr\');\\n";
fwrite($f,$result);
то есть в файле получается массив:
$arr[]=array(1=>\'текст1\',2=>\'текст2\',3=>\'текст3\',4=>\'текст4\',5=>\'текст5\');
$arr[]=array(1=>\'текст1\',2=>\'текст2\',3=>\'текст3\',4=>\'текст4\',5=>\'текст5\');
$arr[]=array(1=>\'текст1\',2=>\'текст2\',3=>\'текст3\',4=>\'текст4\',5=>\'текст5\');
Сделал как знал... Говорят, что при записи нужно использовать serialize, но когда записывал то же с помощью fwrite($f,serialize($result)), все записывалось в одну длинную строчку, а если массив большой...
Посоветуйте как хранить такой массив в отдельном файле правильно и как потом его читать.
PS я испотльзовал для чтения из файла обычный include, а в файле первые 2 символа ставил , чтобы его содержимое не выводилось на экран, таким образом я инициализировал массив $arr в скрипте, чтобы потом можно было к нему обращаться...
-
по-другому будет так:
записываешь
$result="$name|$ur|$mail|$menu|$descr\\n";
заменяя, естеественно, в данных \\r, \\n и | на что-нибудь другое
читаешь -
$arr=file(\'filename.ext\');
в массиве $arr у тебя строки.
массив из каждой строки можно получить, через explode("|",#arr[$i])
это самый, что ни на есть, стандартный способ.
-
Спасибо!
PS а так. как я сделал приемлемо или никуда не годится?
И если выбирать между 3мя способами - моим, тем, что вы написали и сериализацией,у какого будет преимущество? В моем вроде функций ресурсоемких не используется, может будет быстрее работать, но может есть другие недостатки?
-
есть.
все-таки, не стоит исполнять данные.
у теб полуается КОД, а на самом деле - это ДАННЫЕ
а их лучше не смешивать
лучше всего мой.
хотя бы потому, что
1. так делают в подавляющем большинстве случаев.
2. решение масштабирвемое - можно читать не весь файл.
3. можно сделать поиск, к примеру
-
я понял, спасибо за совет!