Поиск определенного сотрудника
Чтобы отобразить информацию об остальном персонале, которая передается через уникальное id внутри нашей ссылки, нужно добавить следующий код прямо после закрывающей фигурной скобки в скрипте letter, как показано ниже:
}//Окончание скрипта if(isset($_GET)){ $contactid=$_GET; //Подключение к базе данных $db=mysql_connect ("servername", "username", "password") or die ('Я не могу подключиться к базе данных, так как: ' . mysql_error()); //-select the database to use $mydb=mysql_select_db("yourDatabase"); //- Запрос к таблице базы данных $sql="SELECT * FROM Contacts WHERE ID=" . $contactid; //- Запустить запрос к функции mysql_query() $result=mysql_query($sql); //- Запуск цикла и сортировка результатов while($row=mysql_fetch_array($result)){ $FirstName =$row; $LastName=$row; $PhoneNumber=$row; $Email=$row; //- Вывести результат в массиве echo "<ul>n"; echo "<li>" . $FirstName . " " . $LastName . "</li>n"; echo "<li>" . $PhoneNumber . "</li>n"; echo "<li>" . "<a href=mailto:" . $Email . ">" . $Email . "</a></li>n"; echo "</ul>"; } }
Здесь мы изменили четыре фрагмента кода:
- Мы используем функцию isset(), и с ее помощью проверяем значение ID в массиве $_GET;
- Создаем переменную $contactid и инициализируем ее массивом $_GET;
- В таблице выделяем все, что отмечено звездочкой *. Звездочка – это сокращенное обозначение в SQL, которое означает «дайте мне все столбцы и строки из таблицы». Чтобы определить, какую информацию выводить, мы упоминаем переменную contactid в конце SQL-выражения;
- Выводим дополнительную информацию о каждом представителе персонала.
Сохраните файл search_byid.php и проверьте результат.
Обратите внимание, что наш функционал работает так, как и положено. При вводе имени или фамилии в поле, или при выборе буквы в качестве гиперссылки, отображаются только имена представителей персонала
Если навести курсор на ссылку, то в строке статуса можно увидеть уникальный ID. Если кликнуть по конкретному человеку, то адресная строка изменится, и отобразится дополнительная информация об этом сотруднике.
Объяснение примера — HTML страницы
Когда пользователь вводит символ в поле ввода выше, выполняется функция .
Функция запускается с помощью событие :
<html>
<head>
<script>
function showResult(str)
{
if (str.length==0) {
document.getElementById(«livesearch»).innerHTML=»»;
document.getElementById(«livesearch»).style.border=»0px»;
return; }
if (window.XMLHttpRequest) { // код для IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}else { // код для IE6, IE5
xmlhttp=new ActiveXObject(«Microsoft.XMLHTTP»); }
xmlhttp.onreadystatechange=function() {
if (this.readyState==4 && this.status==200) {
document.getElementById(«livesearch»).innerHTML=this.responseText;
document.getElementById(«livesearch»).style.border=»1px solid #A5ACB2″;
} }
xmlhttp.open(«GET»,»livesearch.php?q=»+str,true);
xmlhttp.send();}
</script>
</head>
<body>
<form>
<input type=»text» size=»30″ onkeyup=»showResult(this.value)»>
<div id=»livesearch»></div>
</form>
</body>
</html>
Объяснение исходного кода:
Если поле ввода пустое , функция очищает
содержимое заполнителя livesearch и выводит из функции.
Если поле ввода не пустое, функция выполняет следующее:
Создание объекта
Создайте функцию, которая будет выполняться, когда ответ сервера будет готов
Отправить запрос в файл сервера
Обратите внимание, что в URL адрес добавляется параметр (с содержимым поля ввода)
Шаг один: Редукция «посторонних» слов из blob’а
Первая проблема заключается в том, что данные переполнены посторонними словами (предлогами, междометиями..), такими как «как, где, а, и». Эти слова помогают нам, людям, общаться но не имеют ничего общего с нашей проблемой, когда нужно получить вывод по релевантности.
Ниже, в конце статьи, я приложил мой личный список таких, «посторонних», слов.
Итак, мы сейчас пытаемся сделать — выбрать из данных эти слава, и, — в ново созданной табличке с двумя полями: словом и его указателем (счетчиком). Нам необходимо что-то вроде такого:
+-----+---------------+ | qid | word | +-----+---------------+ | 6 | links | | 5 | Fire | | 5 | topics | | 5 | related | | 5 | Shakespeare | | 4 | people | | 4 | Knowpost | | 3 | cuba | | 3 | cigar | +-----+---------------+
Так, давайте создадим собственно табличку:
CREATE TABLE search_table( word VARCHAR(50), qid INT)
Следующим шагом будет — обработать и переместить данные в нашу таблицу search_table.
<?php $query = "SELECT blob,identifier FROM your_table"; $result = mysql_query($query); $number = mysql_numrows($result); $j = 0; WHILE ($j < $number) { /* Наш "blob" */ $body = mysql_result($result,$j,"blob"); /* Наш "identifier */ $qid = mysql_result($result,$j,"qid"); /* Открыть файл с посторонними словами в массив */ $noise_words = file("noisewords.txt"); $filtered = $body; /* Помещаем пробел перед первым словом */ $filtered = ereg_replace("^"," ",$filtered); /* Теперь мы избавились от ненужных слов и можем поместить то, что осталось - в массив */ /* Пробегаем циклом и удаляем неправильные слова */ for ($i=0; $i < count($noise_words); $i++) { $filterword = trim($noise_words); $filtered = eregi_replace(" $filterword "," ",$filtered); } $filtered = trim($filtered); $filtered = addslashes($filtered); $querywords = ereg_replace(",","",$filtered); $querywords = ereg_replace(" ",",",$querywords); $querywords = ereg_replace("\?","",$querywords); $querywords = ereg_replace("\(","",$querywords); $querywords = ereg_replace("\)","",$querywords); $querywords = ereg_replace("\.","",$querywords); $querywords = ereg_replace(",","','",$querywords); $querywords = ereg_replace("^","'",$querywords); $querywords = ereg_replace("$","'",$querywords); /* Теперь мы должны иметь что-то типа 'Word1','Word2','Word3' так что теперь мы можем загнать все в массив */ $eachword = explode(",", $querywords); /* наконец-то мы можем пробежаться по массиву и поместить каждое слово в базу данных, вместе со счетчиком */ for ($k=0; $k < count($eachword); $k++) { $inputword = "INSERT INTO search_table VALUES($eachword,$qid)"; mysql_query($inputword); } /* Пробежаться по циклу еще разок с новыми данными */ $j++; } ?>
Этот скрипт обрабатывает ваши старые данные. Необходимо добавить подобную же обработку на добавление данных в вашу базу данных (когда её вводит пользователь, хозяин — или кто угодно) — так, чтобы база обновлялась в процессе.
Разработка формы
Чтобы создать форму поиска по сайту через , откройте любой подходящий текстовый редактор. Я рекомендую воспользоваться бесплатным PSPad. Вы можете использовать любой текстовый редактор, где предусмотрена подсветка синтаксиса. Это в значительной степени облегчит процесс написания и отладки PHP-кода. Создавая страницу для формы поиска, не забудьте сохранить ее в формате .php, иначе PHP-код не будет обрабатываться должным образом. Как только сохраните документ, скопируйте в него следующую разметку:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Поиск контактов:</title> </head> <p><body> <h3>Детальный поиск контактов</h3> <p>Вы можете искать по имени или фамилии</p> <form method="post" action="search.php?go" id="searchform"> <input type="text" name="name"> <input type="submit" name="submit" value="Search"> </form> </body> </html> </p>
Если вы знакомы с языком HTML, то тут вам все должно быть понятно как минимум до открывающего тега form. Внутри этого тега находится важнейший элемент всего кода – атрибут action. В качестве действия нашей формы мы указали название нашего файла, а затем применили к нему строку запроса “go”.
Поиск по контенту сайта -> файлы DW — search 1.2
04.05.2020
Скачать со страницы
Описание обновлено!
Если мы говорим о поиске по контенту на сайте, который сделан на файлах, то первое с чем мы сталкиваемся, против базы данных, как получить все ссылки на все файлы!?
Другими словами, где у вас есть все ссылки вашего сайта!?sitemap.XML Теперь не нужно$domen = $_SERVER.’://’.$_SERVER ;
1).file_get_contents$ALL_pages = file_get_contents(‘https://dwweb.ru/sitemap.xml’);
2).locpreg_match_allpreg_match_all(«#<loc>(.+?)</loc>#i», $ALL_pages, $url);
3).удалить$fruit = array_shift($url);
4).путь до корневой
+ Получим в переменную $poisk от правленный поисковый запрос.
+ все буквы приведем к нижнему регистру my_strtolower
$home = $_SERVER;
if($_POST){ $poisk = strip_tags ( $_POST );}
$poisk = my_strtolower( $poisk );
5).
if($_POST)
{
if( $poisk )
{
for ($i = 0; $i < count($ALL_PAGES); $i++)
{
if( file_exists( str_replace( $domen , $home , $ALL_PAGES) ) )
{
6).
Теперь весь контент страницы полученный в цикле через file_get_contents переведем в нижний регистр — my_strtolower и внутри получим путь на сревре заменив домен на $home
substr_count
+ если что-то найдено, то создаем счетчик +1($line_count)
+ заносим в переменную $rezult адрес страницы, где это было найдено.
$new = my_strtolower( file_get_contents( str_replace( $domen , $home , $ALL_PAGES) ) );
if (substr_count($new, $poisk))
{
$line_count += 1;
$rezult .= ‘<a href =»‘.$ALL_PAGES.'» target=»_blank»>’.$ALL_PAGES.'</a><br>’ ;
7).if($line_count)($vivod_info)
8).$rezult = ‘Отправлен пустой запрос’;
Далее особо ничего интересного… форма + вывод полученных данных…
Поиск по буквам
Для реализации поиска по буквам потребуется лишь несколько дополнительных строк кода. Добавим этот удобный функционал для посетителей. Таким образом, они смогут находить представителей персонала по буквам, которые содержатся в имени или фамилии.
Добавьте следующую строку кода после закрывающего тега form:
</form> <p><a href="?by=A">A</a> | <a href="?by=B">B</a> | <a href="?by=K">K</a></p> <?php
Мы привязываем тег <a> к строке запроса с by с помощью анкора, и устанавливаем его равным определенной букве. Чтобы реализовать функционал поиска по буквам, нам нужно добавить следующий код прямо после закрывающей фигурной скобки в исходном скрипте, как показано ниже:
}//Окончание скрипта поисковой формы if(isset($_GET)){ $letter=$_GET; //Подключение к базе данных $db=mysql_connect ("servername", "username", "password") or die ('Я не могу подключиться к базе данных, так как: ' . mysql_error()); //-Выберете базу данных $mydb=mysql_select_db("yourDatabase"); //-Запрос к таблице базы $sql="SELECT ID, FirstName, LastName FROM Contacts WHERE FirstName LIKE '%" . $letter . "%' OR LastName LIKE '%" . $letter ."%'"; //-Запустить запрос к функции MySQL Query $result=mysql_query($sql); //-Результаты подсчета $numrows=mysql_num_rows($result); echo "<p>" .$numrows . " results found for " . $letter . "</p>"; //-Запуск цикла и сортировка результатов while($row=mysql_fetch_array($result)){ $FirstName =$row; $LastName=$row; $ID=$row; //-Вывести результат в массиве echo "<ul>n"; echo "<li>" . "<a href="search.php?id=$ID">" .$FirstName . " " . $LastName . "</a></li>n"; echo "</ul>"; } }
Здесь мы изменили четыре фрагмента кода скрипта поиска по сайту:
- Мы используем функцию isset(), и вносим в нее массив $_GET, а затем проверяем значение by;
- Создаем переменную $letter и инициализируем ее значение массивом $_GET;
- Добавляем переменную letter в SQL-запрос;
- Указываем переменную letter внутри выражения, в котором получаем подсчитанное количество строк.
Сохраните файл search_byletter.php и проверьте результат.
В завершение
В сегодняшней статье мы рассмотрели, как сделать поиск по сайту, а также:
- Создавать базы данных и соответствующие таблицы;
- Использовать инструменты для управления базами данных, создавать столбцы и вводить данные;
- Разрабатывать формы поиска на основе PHP, которая умеет осуществлять проверку вводимых данных, наличия переменных в запросе, а также соединяться с базой данных и выводить результаты из таблицы;
- Как защитить приложение и базу данных от SQL-инъекций.
Используя знания, полученные из этой статьи, вы сможете без труда модифицировать чужой код, а также при необходимости расширять функционал формы поиска.
Валентин Сейидовавтор-переводчик статьи «How to Create a Search Feature with PHP and MySQL»
Создание формы авторизации
Теперь перейдем непосредственно к самой авторизации. Создайте файл с названием mylogin.html со следующим содержанием:
<?php mysql_connect ("localhost", "root","");//пишите свои настройки mysql_select_db("test") or die (mysql_error());//и свою бд mysql_query('SET character_set_database = utf8'); mysql_query ("SET NAMES 'utf8'"); error_reporting(E_ALL); ini_set("display_errors", 1); session_start();//не забываем во всех файлах писать session_start if (isset($_POST) && isset($_POST)){ //немного профильтруем логин $login = mysql_real_escape_string(htmlspecialchars($_POST)); //хешируем пароль т.к. в базе именно хеш $password = md5(trim($_POST)); // проверяем введенные данные $query = "SELECT user_id, user_login FROM users WHERE user_login= '$login' AND user_password = '$password' LIMIT 1"; $sql = mysql_query($query) or die(mysql_error()); // если такой пользователь есть if (mysql_num_rows($sql) == 1) { $row = mysql_fetch_assoc($sql); //ставим метку в сессии $_SESSION = $row; $_SESSION = $row; //ставим куки и время их хранения 10 дней setcookie("CookieMy", $row, time()+60*60*24*10); } else { //если пользователя нет, то пусть пробует еще header("Location: mylogin.html"); } } //проверяем сессию, если она есть, то значит уже авторизовались if (isset($_SESSION)){ echo htmlspecialchars($_SESSION)." <br />"."Вы авторизованы <br /> Т.е. мы проверили сессию и можем открыть доступ к определенным данным"; } else { $login = ''; //проверяем куку, может он уже заходил сюда if (isset($_COOKIE)){ $login = htmlspecialchars($_COOKIE); } //простая формочка print <<< html <form action="mylogin.html" method="POST"> Логин <input name="login" type="text" value = $login><br> Пароль <input name="password" type="password"><br> <input name="submit" type="submit" value="Войти"> </form> html; } ?>
Примечание! Если вдруг у Вас отказывает работать парсер php, т.е. на экран Вам выводится сам код php, то у Вас просто на всего не включена обработка php в файлах html. Настройки делаются в файле конфигурации web сервера httpd.conf (если apache):
AddType application/x-httpd-php .php .html
В IIS в окне «Добавление сопоставления модуля» (Add Module Mapping) добавьте к *.php еще и *.html через запятую. Это если Вы делаете у себя дома на своем web сервере, а если Вы все это делаете у хостера, то Вам придется писать им и просить внести необходимые изменения, у некоторых хостеров они уже сделаны.
Нравится13Не нравится13
Создание и настройка базы данных
Для того чтобы перейти к создании базы данных, запускаем сервер и открываем СУБД PHPMyAdmin.
Рис 5. Открываем PhpMyAdmin в Open Server
Нажимаем на ссылку ‘New’.
Рис 6. Создание новой базы данных
Указываем название базы ‘live_search’ и выбираем кодировку ‘utf8mb4_unicode_ci’.
Рис 7. Создание новой базы данных в PhpMyAdmin
Далее, создаем таблицу ‘users’, со столбцами ‘id’ и ‘name’ и наполняем ее данными.
Для этого, в PhpMyAdmin, переходим на вкладке SQL и запускам следующий запрос:
CREATE TABLE users ( id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY, Name VARCHAR(30) NOT NULL ); INSERT INTO `users` VALUES (1, 'Василий'), (2, 'Татьяна'), (3, 'Наталия'), (4, 'Иван'), (5, 'Андрей');
Рис 8. Запуск SQL кода для создания таблицы users
И видим, что данные добавились.
Подключение при помощи PHP к MySQL с расширением PDO
PDO означает PHP Data Objects.
PDO_MYSQL реализует интерфейс PDO, предоставляемый РНР для подключения программы к базе данных MySQL.
В большинстве дистрибутивов Linux (например, CentOS и RedHat), PHP-PDO пакет уже входит в пакет PHP-MySQL. Таким образом, вам не придется искать и устанавливать пакет PHP-PDO. Все, что вам нужно сделать, это установить пакет PHP-MySQL, чтобы получить работающее расширение PDO_MYSQL PHP в вашей системе.
Создайте следующий файл MySQL-pdo.php в вашим Apache DocumentRoot:
<?php try { $conn = new PDO("mysql:host=localhost;dbname=andreyex", "root", "mySecretDBpass"); $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); echo 'Подключение к базе данных.<br>'; $sql = 'SELECT name FROM employee'; print "Имя Сотрудника:<br>"; foreach ($conn->query($sql) as $row) { print $row . "<br>"; } $conn = null; } catch(PDOException $err) { echo "Ошибка: не удается подключиться: " . $err->getMessage(); } ?>
В приведенном выше:
- новый PDO – Создаст новый объект PDO, который будет принимать следующие три аргумента:
- Строка подключения MySQL: будет в формате “mysql:host=$hostname;dbname=$dbname”. В приведенном выше примере, БД работает на локальном хосте, и мы подключаемся к базе данных andreyex.
- Имя пользователя для подключения к MySQL.
- Пароль для пользователя mysql.
- $sql variable – создание запроса SQL, который вы хотите выполнить. В этом примере, мы выбираем столбец name из таблицы employee.
- query($sql) – здесь мы выполняем SQL запрос, который мы только что создали.
- foreach – вот здесь мы пробегаем по вышеуказанным командам и сохраняем их в переменной строке $, а затем мы показываем их с помощью команды печати.
- В MySQL PDO, чтобы закрыть соединение, просто обнулите значение переменной $conn.
При вызове mysqli.php из вашего браузера, вы увидите следующий вывод, что свидетельствует о том, что PHP был в состоянии подключиться к базе данных MySQL и сделать выборку данных.
Подключение к базе данных. Имя Сотрудника: AndreyEx Ruslan Maria Oleg
SQL-инъекция
Причина, по которой мы добавили в наше поле поиска регулярное выражение, заключается в том, чтобы никто не смог вмешаться в наш SQL-запрос. Раньше эта проблема была распространена, и хакеры умудрялись проводить собственные SQL-запросы, манипулируя при этом вашим приложением. Например, если бы мы допустили возможность использовать апостроф в нашем поле, то хакер мог бы просто удалить базу данных, используя запрос:
'DROP TABLE <myTable>
Как уже было отмечено, регулярное выражение гарантирует, что в качестве первого символа посетитель может вводить лишь буквы в нижнем или верхнем регистре.
Экспорт и импорт базы данных
Сначала определимся, что такое дамп базы данных MySQL? Простыми словами, это файл, где хранится копия БД. Информация с этого дампа используется, если понадобится заполнить пустую БД (при смене хостинга или переносе сайта с Denver) или заменить существующую БД (применяется для процесса восстановления). Расширение файла обычно .sql.
Как производится экспорт БД MySQL? Файлы базы данных обычно экспортируются (создается дамп) при помощи интерфейса phpMyadmin. Для выполнения операции придется сделать несколько шагов:
- В панели управления хостингом найдите phpMyadmin. В первую очередь его надо искать в разделе «Базы данных» и т. п.
- Слева в углу выберите базу данных, которая будет экспортирована сначала на ПК, а затем на другой хостинг.
- Нажмите на вкладку «Экспорт». На данном этапе может потребоваться выбор способа экспорта: «Обычный» с множеством настроек или «Быстрый», где настроек будет немного. На дальнейшие действия выбор никакого значения не окажет — главное, чтобы вы изменили только указанные далее настройки.
- Выберите все таблицы. Для этого нажмите на кнопку «Выделить все».
- Отметьте галочкой «Сохранить как файл», «Сохранить вывод в файл» или что-то наподобие в списке меню перед вами.
- На всякий случай запомните кодировку, не трогая ее при этом.
- Нажмите «Ок» и сохраните файл с БД на ПК.
Экспорт и импорт базы данных
Другой способ экспортирования базы данных — с помощью протокола SSH. Для этого используйте специальную SSH-команду:
mysqldump —user=DBUSER —password=USERPASSWORD DBNAME > DUMPFILENAME.sql
либо
mysqldump -uDBUSER -pUSERPASSWORD DBNAME > DUMPFILENAME.sql
Вместо слов, набранных заглавными буквами, подставьте:
DBUSER — имя пользователя базы данных, например, uhosting_databaseuser;
USERPASSWORD — пароль пользователя БД, например, Alan2016;
DBNAME — имя БД, откуда будут экспортироваться данные, например, uhosting_databasename;
DUMPFILENAME — имя dump-файла, в который будет производиться экспорт. Здесь вы можете указать путь, куда надо сохранить дамп-файл. Советуем этого не делать, просто забрав потом файл с сервера хостинг-провайдера.
Импорт БД
Под этой процедурой подразумевается перенос информации из одной базы данных (A) в другую (B). Зачастую база данных B располагается на хостинге (или на Denver), а база данных A — на компьютере пользователя (в виде файла с расширением .sql). База данных A имеет еще одно название — дамп.
Чтобы совершить импорт удаленной базы данных MySQL, найдите phpMyAdmin в панели управления хостингом (обычно находится в меню «Базы данных»). В phpMyadmin выберите необходимую БД, куда хотите сделать импорт данных. Определившись с базой данных, нажмите на вкладку «Импорт», затем «Обзор» — выбираете сохраненную на ПК базу данных. Не забудьте проверить идентичность кодировок. Больше менять ничего не нужно. После нажатия «Ок» ваша база данных добавится к той, что находится на хостинге.
Опишем также процедуру импорта базы данных MySQL с помощью SSH, хотя она применяется довольно редко. Сначала добавьте БД, откуда будут импортироваться данные, на сервер хостинг-провайдера, где хранятся файлы вашего сайта. Затем для импорта БД используйте команду:
mysql -uUSERNAME -pUSERPASSWORD DBNAME < DUMPFILENAME.sql
либо
mysql —user=USERNAME —password=USERPASSWORD DBNAME < DUMPFILENAME.sql
Вместо слов, набранных заглавными буквами, подставьте данные по схеме, описанной в части об экспорте БД
Обратите внимание, что на место DUMPFILENAME необходимо не только подставить имя dump-файла, откуда будут импортироваться данные, но и еще указать путь к БД, которую вы добавляли на сервер хостинг-провайдера
Зачастую систему управления базами данных MySQL ныне используют как имя нарицательное для общего понятия СУБД. Все из-за огромной популярности — ей пользуются Facebook, Google, Twitter и другие известные корпорации. Несмотря на то, что существует множество неплохих аналогов, имеющих определенные преимущества в тех или иных сферах, на лидирующих позициях остается все-таки MySQL. Пользователи баз данных со всего мира ценят ее за универсальность, простоту и надежность.
Алгоритм работы MySQL
Одно или несколько устройств (клиентов) подключаются к серверу по определенной сети. Любой из них может сделать запрос из графического интерфейса пользователя (GUI) на своем мониторе. Сервер покажет требуемый результат, если все идет строго по инструкции. Основные процессы, происходящие в среде MySQL (если не вдаваться в технические тонкости), одинаковы:
- MySQL создает БД для хранения и управления данными, определяющими отношения каждой таблицы.
- Клиенты запрашивают информацию, путем ввода определенных команд SQL на MySQL.
- Приложение сервера выдает клиенту запрошенные сведения.
Клиенты обычно выбирают подходящий им MySQL GUI. Чем проще и удобнее графический пользовательский интерфейс, тем быстрее и легче станут происходить операции по управлению данными. Наиболее популярные графические интерфейсы MySQL: SequelPro, MySQL WorkBench, DBVisualizer и Navicat DB Admin Tool.
Какие-то из них бесплатны, а некоторые распространяются на коммерческой основе. Одни работают на всех ОС, а другие только на MacOS. Соответственно каждый пользователь должен подобрать GUI под свои нужды. Чтобы управлять базами данных MySQL, в том числе на сайте WordPress, наиболее очевидным подходом является phpMyAdmin.
Вывод массива в html таблицу (php)
Просмотрел свои последние посты и понял что сильно ушёл в python. Язык он конечно достойный но не единственный ;). Тематику webpy я обязательно продолжу но как нибудь потом.
Очень часто несмотря на мои личные предпочтения мне приходится работать в php. В основном это веб приложения. Даже не в основном а именно только они :). Ну это не суть, а вступление. В этой статье я хотел рассмотреть одну тривиальную задачу. В процессе создания сайта а иногда даже просто странички возникает необходимость вывести данные содержащиеся в массиве в виде html таблицы с определённым числом колонок. Задача вовсе не сложная. Она заключается в определении момента (итерации цикла) когда нужно вывести теги <tr> и </tr>. Для этой задачи у меня есть собственное решение которое мне кажется изящным. Чем я и хочу с вами поделиться.
- <?
- $arData = array(); // массив с данными которые надо вывести
- $column = 3; // количество колонок в таблице
- $items = count($arData); // общее количество выводимых элементов
- $i = 1; // счётчик итераций
- if ($items <= $column) $arRange1 = array(1);
- else $arRange1 = range(1, $items, $column);
- if ($items <= $column) $arRange2 = array($column);
- else $arRange2 = range($column, $items, $column);
- ?>
- <table cellpadding=»0″ cellspacing=»0″>
- <?foreach($arData as $item):?>
- <?if(array_search($i, $arRange1) !== FALSE) echo «<tr>»?>
- <td width=»<?=round(100/$column)?>%»><?=$item?></td>
- <?if(array_search($i, $arRange2) !== FALSE) echo «</tr>»;$i++?>
- <?endforeach?>
- <?if($items%$column != 0) echo str_repeat(‘<td width=»‘.round(100/$column).’%»> </td>’, ($column-$items%$column)).»</tr>»?>
- </table>
UPD 7 февраля 2012 г.
А вот ещё один вариант придумался, мне кажется он несколько проще
- <?
- $arData = array(); // массив с данными которые надо вывести
- $column = 3; // количество колонок в таблице
- $i = 0; // счётчик итераций
- ?>
- <table cellpadding=»0″ cellspacing=»0″>
- <?foreach($arData as $item):?>
- <?if($i == 0) echo «<tr>»?>
- <td width=»<?=round(100/$column)?>%»><?=$item?></td>
- <?$i++?>
- <?if($i == $column) {echo «</tr>»; $i=0;}?>
- <?endforeach?>
- <?if($i != 0) echo str_repeat(‘<td width=»‘.round(100/$column).’%»> </td>’, ($column-$i)).»</tr>»?>
- </table>