Премини към съдържанието
  • Добре дошли!

    Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

    Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

     

Малко помощ за PHP/TXT DB


Препоръчан отговор


Здравейте, колеги! ;)

Написах си една системка за добавяне на Име, Фамилия и E-mail, ползваща текстова база данни (да се разбира като Адресна книга). Но срещнах трудност, с която явно не мога да се справя. Затова и търся вашата помощ!

Необходимо ми е да направя следните неща:

1) Да показва колко на брой са записите в add.html (Вероятно просто да изброи колко реда от БД са заети).

2) Да се направи проверка дали контактът не съществува вече (Вероятно да търси по e-mail, тъй като не едно куче се казва Шаро biggrin.gif).

Ето и кодовете на файловете ми:

add.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"

	"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">


<html xmlns="http://www.w3.org/1999/xhtml">

<head>

	<meta http-equiv="Content-Type" content="text/html; charset=windows-1251" />

</head>

<body>

<div align="left">

	<form method="post" action="save.php">

		Име: <input type="text" name="name"><br/>

		Фамилия: <input type="text" name="lastname"><br/>

		E-mail: <input type="text" name="email"><br/>


		<br/><input type="submit" name="Запази">

	</form>

	<br/>

	<br/>

	<br/>

	<a href="all.php">Всички записи</a>

</div>

</body>

</html>
all.php
<?php 


$file = file("db.ini"); 

$n = count($file); 

echo '<table border=1> 

<tr> 

	<td>Име: </td>

	<td>Фамилия: </td>

	<td>E-mail: </td> 

</tr> 

'; 


for ($i=0; $i<$n;$i++) 

{ 

	$line = explode ("&",$file[$i] ); 

	echo ' 

	<tr> 

		<td>'.$line[0].'</td>

		<td>'.$line[1].'</td>

		<td>'.$line[2].'</td>

	</tr>'; 

} 


?>
save.php
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"

	"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">


<html xmlns="http://www.w3.org/1999/xhtml">

<head>

	<meta http-equiv="Content-Type" content="text/html; charset=windows-1251" />

</head>

<body>


<?php 


$name = $HTTP_POST_VARS['name']; 

$lastname = $HTTP_POST_VARS['lastname'];

$email = $HTTP_POST_VARS['email'];


$zapis = $name.'&'.$lastname.'&'.$email." \n"; 


// Записваме данните във файла, служещ за база данни

$fp = fopen ( "db.ini" ,"a"); 

fwrite($fp, $zapis ); 

fclose($fp); 


echo 'Данните са добавени успешно! <br/><br/> <a href="all.php">Всички записи</a>'; 


?>

И разбира се файлът db.ini със записите.

Предварително много благодаря на отзовалите се!

Поздрави и лек ден! :)

Редактирано от BoByS (преглед на промените)
Линк към този отговор
Сподели в други сайтове

1) Да показва колко на брой са записите в add.html (Вероятно просто да изброи колко реда от БД са заети).

2) Да се направи проверка дали контактът не съществува вече (Вероятно да търси по e-mail, тъй като не едно куче се казва Шаро biggrin.gif).

Как така записите в add.html ? Нали се записват в db.ini ?

1. Функция за преброяване на редовете във файл :

 echo countLines("/path/to/file.txt");


 /**

 *

 * @Count lines in a file

 *

 * @param string filepath 

 *

 * @return int

 *

 */

 function countLines($filepath) 

 {

	/*** open the file for reading ***/

	$handle = fopen( $filepath, "r" );

	/*** set a counter ***/

	$count = 0;

	/*** loop over the file ***/

	while( fgets($handle) ) 

	{

		/*** increment the counter ***/

		$count++;

	}

	/*** close the file ***/

	fclose($handle);

	/*** show the total ***/

	return $count;

 }

2. Може да използваш горната функция за да провериш дали даден e-mail вече съществува, като преди това, преобразуваш реда към малки букви.

Линк към този отговор
Сподели в други сайтове
Как така записите в add.html ? Нали се записват в db.ini ?

Не се изразих правилно. В мислите ми беше това, в add.html просто да извежда числото (броя) на записите. :lol6:

Кодът работи перфектно, първото условие е готово. По второто се работи.

Кодът в add.php (метаморфира от add.html):

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"

	"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">


<html xmlns="http://www.w3.org/1999/xhtml">

<head>

	<meta http-equiv="Content-Type" content="text/html; charset=windows-1251" />

</head>

<body>

<div align="left">

	<form method="post" action="save.php">

		Име: <input type="text" name="name"><br/>

		Фамилия: <input type="text" name="lastname"><br/>

		E-mail: <input type="text" name="email"><br/>


		<br/><input type="submit" name="Запази">

	</form>

	<br/>

	<br/>

	<br/>

	<a href="all.php">Всички записи</a>

</div>

<br/><br/>Брой записи:<br/>

<?php

// Функция за извеждането на броя записи в Базата данни

echo countLines("db.ini");

function countLines($filepath) 

{

	/*** open the file for reading ***/

	$handle = fopen( $filepath, "r" );

	/*** set a counter ***/

	$count = 0;

	/*** loop over the file ***/

	while( fgets($handle) ) 

	{

		/*** increment the counter ***/

		$count++;

	}

	/*** close the file ***/

	fclose($handle);

	/*** show the total ***/

	return $count;

}

?>

</body>

</html>

Поздрави! :)

П.п. Не, явно ще ми е необходимо още малко помощ и с функция за сравняване... Уж намирам e-mail-а, извършвам премахване на интервали, & и \n, но след това нищо. Само ми изписва, че e-mail-ът вече съществува, но не може да извърши никакво действие и отново си записва във файла. :)

Редактирано от BoByS (преглед на промените)
Линк към този отговор
Сподели в други сайтове

Все още е актуална молбата ми за помощ...

Докъде стигнах. Вече успешно брои колко са записите във файла, но упорито отказва да проверява за повтарящ се e-mail. След мъчително мислене и умуване по темата, ме озари мисълта, че проверката трябва да се извършва преди записването на данните в текстовия файл (привидно очевадно :P ), т.е. във файла save.php. Ето докъде съм стигнал:

<?php 

$name = $HTTP_POST_VARS['name']; 

$lastname = $HTTP_POST_VARS['lastname'];

$email = $HTTP_POST_VARS['email'];


$zapis = $name.'&'.$lastname.'&'.$email." \n"; 


// Започвам обхождането по файла

$handle = fopen( "db.ini", "r");

$k = count($handle);


for ($i=0;$i<$k;$i++) {

// Премахвам интервали, & и \n последователно

$handlee=$handle[$i]; 

$handlee=str_replace(" ","",$handlee); 

$handlee=str_replace("&","",$handlee); 

$handlee=str_replace("\n","",$handlee);


if (eregi ($email,$handlee)) {

	echo 'Такъв потребител вече съществува!';

} else {

// Записваме данните във файла

$fp = fopen ( "db.ini" ,"a"); 

fwrite($fp, $zapis ); 

fclose($fp); 


echo 'Данните са добавени успешно! <br/><br/> <a href="all.php">Всички записи</a>'; 

// echo '<meta http-equiv="Refresh" content="5; url=add.php">';

}

}

?>

Но просто си ги записва във файла. Явно греша при обхождането, но логиката ми е да търся съответствие и "търсачката", тършуваща по редовете... :wors: Някой има ли идея?

Поздрави!

Редактирано от BoByS (преглед на промените)
Линк към този отговор
Сподели в други сайтове

Защо просто не намериш последната позиция на & в ред от файла, вземеш всичко оттам до края на реда (email0а) и не сравниш с новия, като преди това конвертираш до малки букви ?

Според мен и твоя код трябва да работи коректно, и без премахванията на " ",& и \n. Провери какво сравняваш.

Редактирано от Ken (преглед на промените)

Линк към този отговор
Сподели в други сайтове
  • 2 седмици по-късно...

Защо просто не намериш последната позиция на & в ред от файла, вземеш всичко оттам до края на реда (email0а) и не сравниш с новия, като преди това конвертираш до малки букви ?

Според мен и твоя код трябва да работи коректно, и без премахванията на " ",& и \n. Провери какво сравняваш.

Meрси за помощта, Кен! :) От няколко дена вече работи проверката в текстовия файл, но в крайна сметка за ползване от потребителите използвах проста MySQL таблица.

Поздрави!

Линк към този отговор
Сподели в други сайтове

Добавете отговор

Можете да публикувате отговор сега и да се регистрирате по-късно. Ако имате регистрация, влезте в профила си за да публикувате от него.

Гост
Напишете отговор в тази тема...

×   Вмъкнахте текст, който съдържа форматиране.   Премахни форматирането на текста

  Разрешени са само 75 емотикони.

×   Съдържанието от линка беше вградено автоматично.   Премахни съдържанието и покажи само линк

×   Съдържанието, което сте написали преди беше възстановено..   Изтрий всичко

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Добави ново...

Информация

Поставихме бисквитки на устройството ви за най-добро потребителско изживяване. Можете да промените настройките си за бисквитки, или в противен случай приемаме, че сте съгласни с нашите Условия за ползване