|
0 / 0 / 0
Регистрация: 10.01.2012
Сообщений: 15
|
|
Поиск в xml и вывод результата!31.10.2013, 19:28. Показов 1908. Ответов 3
Метки нет (Все метки)
Люди добрые,можете помочь?!
Проблема заключается в следующем,есть БД Postgresql с кодировкой win-1251 (другая кодировка не выставляется) и есть написанный код который ищет по xml документу слово.xml документ хранится в бд,при нахождение искомого слова,код выводит его,так вот,если вводится английское слово,то английский текст выводится без проблем а русский одни каракули,если вводить в поиске русские буквы,то выдает ошибку Warning: preg_match() [function.preg-match]: Compilation failed: invalid UTF-8 string at offset 1 Можете сказать,как,где и что надо написать,что бы этой ошибки не было и что бы выводилось все нормально,даже при вводе русских букв или слов код программы: <?php header( 'Content-Type: text/html; charset=utf-8'); if (isset($_GET['search']) && ($_GET['search'] != "")) { // поисковой запрос $str = $_GET['search']; function prepString($str) { // шаблоны для поиска $pattern = array( 1 => '/((ив|ивши|ившись|ыв|ывши|ывшись)|((?<=[ая])(в|вши|вшись)))$/', 2 => '/(с[яь])$/', 3 => '/(ее|ие|ые|ое|ими|ыми|ей|ий|ый|ой|ем|им|ы м|ом|его|ого|еых|ую|юю|ая|яя|ою|ею)$/', 4 => '/((ивш|ывш|ующ)|((?<=[ая])(ем|нн|вш|ющ|щ)))$/', 5 => '/((ила|ыла|ена|ейте|уйте|ите|или|ыли|ей|у й|ил|ыл|им|ым|ены|ить|ыть|ишь|ую|ю)|((?< =[ая])(ла|на|ете|йте|ли|й|л|ем|н|ло|но|ет|ют| ны|ть|ешь|нно)))$/', 6 => '/(а|ев|ов|ие|ье|е|иями|ями|ами|еи|ии|и|ие й|ей|ой|ий|й|и|ы|ь|ию|ью|ю|ия|ья|я)$/' ); // подготовка строки для поиска if ( preg_match($pattern[1], $str) ) { $test = preg_replace($pattern[1], '.*', $str); } else if( preg_match($pattern[2], $str) ) { $test = preg_replace($pattern[2], '.*', $str); } else if( preg_match($pattern[3], $str) ) { $test = preg_replace($pattern[3], '.*', $str); } else if( preg_match($pattern[4], $str) ) { $test = preg_replace($pattern[4], '.*', $str); } else if( preg_match($pattern[5], $str) ) { $test = preg_replace($pattern[5], '.*', $str); } else if( preg_match($pattern[6], $str) ) { $test = preg_replace($pattern[6], '.*', $str); } else { $test = $str . '.*'; } return $test; } // формируем строку для поиска $str = explode(" ", trim($str)); $search = '/'; foreach ( $str as $val ) { $search .= prepString($val); } $search .= '/usi'; // устанавливаем соединение с БД $db = pg_connect("host=localhost dbname=labsxml user=postgres password= ") or die("Ошибка подключения к БД:" . pg_last_error()); $sql = 'SELECT name, opicanie FROM "gods"'; $query = pg_query($db, $sql) or die("Ошибка запроса:" . pg_last_error()); while ( $data = pg_fetch_array($query, NULL, PGSQL_ASSOC) ) { $result[] = $data; } foreach ( $result as $val ) { if ( preg_match($search, $val['name']) ) { echo $val['opicanie']; echo '<br>'; } } pg_close($db); } ?>
0
|
|
| 31.10.2013, 19:28 | |
|
Ответы с готовыми решениями:
3
Поиск строк, и вывод результата Поиск по БД, вывод в результата в dataGridView Поиск по колонке Address м вывод результата |
|
1263 / 977 / 384
Регистрация: 02.09.2012
Сообщений: 3,020
|
|
| 01.11.2013, 17:56 | |
|
Попробуйте у клиентской части выставить кодировку. Насколько я понял из ошибки - вы работаете в UTF8. Сделайте вызов: pg_client_enconding(...только здесь я не знаю, что нужно для PHP поставить...)
Все про кодировку смотрите здесь
1
|
|
|
0 / 0 / 0
Регистрация: 10.01.2012
Сообщений: 15
|
||
| 06.11.2013, 11:48 [ТС] | ||
|
Просто белый экран выводит,хотя слова которые я ввожу в поисковой форме присутствуют в тексте.В чем может быть проблема? У меня установлен Denwer (PHP 5.3.13, MySQL 5.1, PostgreSQL 8.4 etc.),а бд в Postgresql ставит таблицы в кодировке только win-1251. Если вводить английские слова,то выводит текста происходит,а русских нет Подскажите в чем может быть причина?(((
0
|
||
|
1263 / 977 / 384
Регистрация: 02.09.2012
Сообщений: 3,020
|
|
| 06.11.2013, 16:03 | |
|
Не знаю, что посоветовать. Про PHP знаю только то, что он существует
![]() Возможно поможет некий подход к локализации проблемы. Если на PHP-сервер есть возможность обращаться к базе данных напрямую (через psql), сначала проверьте ваш запрос через psql. Если вы результат увилите в нормальных русских буквах, значит PostgreSQL с большой вероятностью не причем (с учетом автоперекодироваки, которую должен делать libpq). Как искать проблему в PHP - не знаю, просто не знаком.
0
|
|
| 06.11.2013, 16:03 | |
|
Помогаю со студенческими работами здесь
4
Вывод результата на форму, поиск по директориям Поиск в текстовом файле и вывод результата в TextBox Поиск совпадения информации в таблице и вывод результата swi prolog, поиск факториала, вывод результата
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение.
И на уровне агентов добавится между грибами или бактериями взаимодействий.
До того я пробовал подход через многомерные массивы,. . .
|
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Сочетание глобально распределённой вычислительной мощности и инновационных. . .
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|