|
|
|
| Допустим, есть файл test.txt – В этот файл нужно сделать запись, вроде бы все легко. .)))
Но есть одно но, запись нужно сделать не в конец, не в середину, а в начало файла.
Вот простенький пример.
<?
$gf = "./test.txt";
echo '<form name="form">
Поле1:<br> <input type="text" name="pole1"><br>
Поле2:<br> <textarea name="pole2" rows="3"></textarea>
<input type="submit" name="start" value="Отправить">
</form>';
if(!isset($start)) {} elseif(empty($pole1)) { echo "!"; } elseif(empty($pole2)) { echo "!"; }
$ms = "$pole1 $pole2";
$filename = fopen("$gf", "r+");
fwrite($filename, "$ms");
?>
|
Если будет так, то в файл запишутся строки, но удалятся те, которые уже есть. (То есть строки перезапишутся.)
Если мы изменим r+ на w или на w+, будет тоже самое…
Если a или a+ - будет добавлены строки в конец файла.
Все это конечно хорошо, но не совсем логично. Ведь проще читать файл с начала чем с конца?. .)))
Вопрос, как осуществить запись в файл, не в середину и не в конец, а в начало файла, аналогично a+ только с точностью, да на оборот…?
P.S.
Изучаю я PHP всего недельки две, три… и наткнулся вот на это… о чем собственно и написал. :)
Я пробовал использовать функции fseek(), делал временный файл… и все равно, того чего хотел у меня не получалось :( | |
|
|
|
|
|
|
|
для: SSgv
(01.03.2006 в 23:27)
| | Даже не знаю, может не самый легкий вариант, но я бы сделал так (хотя не проверял, может и не будет работать :)))) )
$a=0;
$text = "$pole1|$pole2";
$fp=fopen("test.txt", "a+");
flock ($fp, LOCK_EX);
ftruncate ($fp,0);//УДАЛЯЕМ СОДЕРЖИМОЕ ФАЙЛА
for ($i=0;$i< sizeof($file);$i++)
{ if ($a==$i) {fputs($fp,"\r\n$text\r\n");} else {fputs($fp,$file[$i]);} }
fflush ($fp);//очищение файлового буфера
flock ($fp,LOCK_UN);
fclose($fp);
|
В файле test.txt первая строчка должна быть пустая и спущена вниз на следущую :)
пусто
pole1|pole2
pole1|pole2
pole1|pole2
|
| |
|
|
|
|
|
|
|
для: midav
(02.03.2006 в 00:14)
| | to SSgv .
Зачем надо записывать в начало, чего ты хочешь добиться, для чего это? | |
|
|
|
|
|
|
|
для: ed209
(02.03.2006 в 02:18)
| | Код приведенный midav не работает :(
Зачем мне это нужно?
Я могу назвать очень много причин, так удобней читать файл, так проще выводить сообщения, и т.д.
И я думаю, будет правильней нежели чем, писать в конец файла. Логичней. | |
|
|
|
|
|
|
|
для: SSgv
(02.03.2006 в 02:35)
| | А почему нельзя создать
рабочий файл, куда будут записываться предыдущие записи,
потом главный очищается,
в него записывавается новаю строка,
а потом в конец записываются строки из рабочего файла.
Код дать немогу,извини, нет времени. | |
|
|
|
|
|
|
|
для: SSgv
(02.03.2006 в 02:35)
| | Можно сделать так:
<?php
$file_name = "file.txt";
$file = file_get_contents ($file_name);
$string = "text";
$fp = fopen ($file_name, "w+");
fwrite ($fp, $string . "\n" . $file);
fclose ($fp);
?>
|
Но лучше все же записывать в конец. Так, ИМХО, удобнее. А при выводе сообщений, занести их в массив и воспользоваться функцией rsort(). | |
|
|
|
|
|
|
|
для: SSgv
(02.03.2006 в 02:35)
| | Писать почти наверняка придется всё же в конец файла. Просто в слиу того факта, что именно в конце файла распределяется файловое пространство. А вот читать его, ежели приспичит (например, если файл настолько большой, что в память его класть целиком неудобно/невозможно), можно и в обратном направлении. Хотя и с несколько меньшей эффективностью. | |
|
|
|
|
|
|
|
для: Trianon
(02.03.2006 в 10:38)
| | Ну нифига не работает мой вариант, ты хоть его проверял? Я вот только что протестил, запись идет в начало файла :)
<?php
if($act=='add') {
$a=0;
$text = "$pole1|$pole2";
$file=file("test.txt");
$fp=fopen("test.txt", "a+");
flock ($fp, LOCK_EX);
ftruncate ($fp,0);//УДАЛЯЕМ СОДЕРЖИМОЕ ФАЙЛА
for ($i=0;$i< sizeof($file);$i++)
{ if ($a==$i) {fputs($fp,"\r\n$text\r\n");} else {fputs($fp,$file[$i]);} }
fflush ($fp);//очищение файлового буфера
flock ($fp,LOCK_UN);
fclose($fp);
}
else {
print"<form action='zapisj_vna4alo.php?act=add' method=post>
<input type=text name=pole1><br>
<input type=text name=pole2><br>
<input type=submit value='dobavitj'></form>";
}
?>
|
Просто сначала в файл test.txt надо самому заполнить вторую и третью строчку
(первая строка свободна)
kruto|kruto
yo|yo
poka|poka
|
И всё хорошо работает :) | |
|
|
|
|
|
|
|
для: midav
(02.03.2006 в 22:23)
| | >Ну нифига не работает мой вариант,
Я такого не утверждал.
>ты хоть его проверял?
Нет, не проверял. Я на слово верю.
....
>И всё хорошо работает :)
Всё хорошо работает, пока файл в память влезает. А потом? | |
|
|
|
|
|
|
|
для: Trianon
(02.03.2006 в 22:31)
| | В смысле в память влезает? | |
|
|
|
|
|
|
|
для: midav
(02.03.2006 в 22:36)
| | В очень простом смысле.
Под PHP-процесс распределяется память. Оперативная (или виртуальная, не столь важно) память сервера. Файл может оказаться на порядок длинее, чем то количество памяти, которое php-процессу дадут съесть. | |
|
|
|
|
|
|
|
для: midav
(02.03.2006 в 22:36)
| | Под скрипт отводится строго определённое количество памяти, обычно 8 Мб, реже 16 - если файл мегабайт 10, а скрипт пытается поместить его содержимое в свою переменную, то он аварийно завершается из-за нехватки памяти. | |
|
|
|
|
|
|
|
для: cheops
(02.03.2006 в 22:40)
| | Ну так по вашим словам скрипты на файлах вообще не стоит делать :)))) | |
|
|
|
|
|
|
|
для: midav
(02.03.2006 в 22:46)
| | Думал, думал, так я и не понял. .))) Почему нету режима записи в начало файла, а режим записи в конец a+ например есть? Это странно. …)))
8мб текста это круто..))) | |
|
|
|
|
|
|
|
для: SSgv
(03.03.2006 в 01:18)
| | потому что файл - структура данных, оптимизированная по критерию скорости последовательного доступа в прямом направлении. И используется она в этом качестве в подавляющем большинстве случаев.
Круто не 8 мб текста. "Круто", когда скрипт, которому по своей алгоритмической природе достаточно 80-800кб, захватывает под себя 8 мб. Потому что так написан. А еще "круто", когда у хостера таких скриптов выполняется одной машиной на полусотне виртуальных серверов одновременно. А пользователи потом воют, что хостинг тормозит зело круто. | |
|
|
|
|
|
|
|
для: SSgv
(03.03.2006 в 01:18)
| | >8мб текста это круто..)))
Да я тоже потешался, пока в последнее время не пошла буквально эпидемия 10Мб XML-файлов, которые нужно разбирать и помещать в базу данных - когда скриту отводится только 8 Мб - веселуха полная... | |
|
|
|