Вопрос по php, preg-replace, utf-8, decode – PHP заменяет специальные символы, такие как à-> a, è-> e

37

У меня есть документ php signup.php, который сохраняет содержимое из формы (в документе form.php) в базу MySQL. Проблема возникает, когда я хочу переформатировать входной контент. Я хочу сделать декодирование символов UTF-8, таких как & # xE0; ->.

<code>  $first_name=$_POST['first_name'];
  $last_name=$_POST['last_name'];
  $course=$_POST['course'];

  $chain="prêt-à-porter";

$pattern = array("'é'", "'è'", "'ë'", "'ê'", "'É'", "'È'", "'Ë'", "'Ê'", "'á'", "'à'", "'ä'", "'â'", "'å'", "'Á'", "'À'", "'Ä'", "'Â'", "'Å'", "'ó'", "'ò'", "'ö'", "'ô'", "'Ó'", "'Ò'", "'Ö'", "'Ô'", "'í'", "'ì'", "'ï'", "'î'", "'Í'", "'Ì'", "'Ï'", "'Î'", "'ú'", "'ù'", "'ü'", "'û'", "'Ú'", "'Ù'", "'Ü'", "'Û'", "'ý'", "'ÿ'", "'Ý'", "'ø'", "'Ø'", "'œ'", "'Œ'", "'Æ'", "'ç'", "'Ç'");

$replace = array('e', 'e', 'e', 'e', 'E', 'E', 'E', 'E', 'a', 'a', 'a', 'a', 'a', 'A', 'A', 'A', 'A', 'A', 'o', 'o', 'o', 'o', 'O', 'O', 'O', 'O', 'i', 'i', 'i', 'I', 'I', 'I', 'I', 'I', 'u', 'u', 'u', 'u', 'U', 'U', 'U', 'U', 'y', 'y', 'Y', 'o', 'O', 'a', 'A', 'A', 'c', 'C'); 

$chain = preg_replace($pattern, $replace, $chain);

echo $chain; // print pret-a-porter

$first_name =  preg_replace($pattern, $replace, $first_name);

echo $first_name; // does not change the input!?!
</code>

Почему он отлично работает для $ chain, но для $ first_name или $ last_name не работает?

Также я стараюсь

<code>echo $first_name; // print áááááábéééééébšššš
$trans = array("á" => "a", "é" => "e", "š" => "s");
echo strtr("áááááábéééééébšššš", $trans); // print aaaaaabeeeeeebssss
echo strtr($first_name,$trans);  // print áááááábéééééébšššš
</code>

но проблема, как видите, та же!

Как упоминает phant0m, вам нужно внимательно следить за всеми вашими кодировками. Кодировка по умолчанию с использованием POST - ISO-8859-1, если вы не укажете, что именно хотите. (Accept-Charset = & APOS; UTF-8 & APOS;) dmp
Ваш файл имеет правильную кодировку? Содержимое в $ _POST имеет одинаковую кодировку? (т. е. тот, который вы установили в браузере для отображения страницы?) Вы также можете установить флаг Юникода для preg_replace phant0m
добавил пару примеров функций :) dmp
Большое спасибо за вашу помощь, когда я добавляю accept-charset = & quot; UTF-8 & quot; в & lt; форме action = & quot; sign_up.php & quot; Способ = & Quot; запись & Quot; Accept-кодировка = & Quot; UTF-8 & Quot; & GT; код работает отлично. Zoran Đukić

Ваш Ответ

6   ответов
1

$this->load->helper('text');

$string = convert_accented_characters($string);

Эта функция использует файл конфигурации компаньонаapplication/config/foreign_chars.php определить для и от массива для транслитерации.

https://www.codeigniter.com/user_guide/helpers/text_helper.html#ascii_to_entities

Это помогло мне после дня разочарования .. Действительно хороший ответ для Codeigniter
1- Вопрос был задан более 2 лет назад. 2- На вопрос принят ответ. 3- ОП не упомянулCI Framework и используетplain php поэтому ваш ответ не имеет ничего общего с вопросом. пожалуйста, уделите больше внимания вопросам, прежде чем отправлять ответ
14

$translatedString = transliterator_transliterate('Any-Latin; Latin-ASCII; [\u0080-\u7fff] remove', $string);
работает как шарм
4

что я нашел эту тему раньше. Функция, которую я сделал (это заняло у меня слишком много времени) ниже:

function CheckLetters($field){
    $letters = [
        0 => "a à á â ä æ ã å ā",
        1 => "c ç ć č",
        2 => "e é è ê ë ę ė ē",
        3 => "i ī į í ì ï î",
        4 => "l ł",
        5 => "n ñ ń",
        6 => "o ō ø œ õ ó ò ö ô",
        7 => "s ß ś š",
        8 => "u ū ú ù ü û",
        9 => "w ŵ",
        10 => "y ŷ ÿ",
        11 => "z ź ž ż",
    ];
    foreach ($letters as &$values){
        $newValue = substr($values, 0, 1);
        $values = substr($values, 2, strlen($values));
        $values = explode(" ", $values);
        foreach ($values as &$oldValue){
            while (strpos($field,$oldValue) !== false){
                $field = preg_replace("/" . $oldValue . '/', $newValue, $field, 1);
            }
        }
    }
    return $field;
}
просто обозначение, лишние начальные скобки в начале функции должны быть удалены
Хороший кусок кода, однако он не работает, если первый символ «грязный». Попробуй CheckLetters (& apos; & # xE5; & # xE4; & # xF6; & apos;);
Это гениальный кусок кода. Особенно для поиска в базах данных, которые имеют противоречивые данные. Я использую его для поиска в базе данных страны, которая заполнена данными, предоставленными пользователем. Это действительно помогает не добавлять неправильно написанное содержание пользователя. Большие пальцы от меня.
@sboss спасибо, что указал на это. Был вызванwhile (strpos($field,$oldValue)) as strpos возвращает 0, если символ найден в индексе 0 строки. Исправлено, выполнивNot Identical сравнение.
Спасибо за ответ. Неправильно введенный пользовательский контент - именно поэтому это было написано :)
8

что и символы в массиве - возможно, даже вероятно, что строка $ first_name находится в другой кодировке, и поэтому эти символы не совпадают. Вы можете попробовать использовать многобайтовые строковые функции.

Попробуйте mb_convert_encoding. Вы также можете попробовать использовать HTML_ENTITIES в качестве параметра to_encoding, тогда вам не нужно беспокоиться о том, как символы будут конвертированы - это будет очень предсказуемо.

Предполагая, что вы вводите этот скрипт в UTF-8, вероятно, неплохое место для начала ...

$first_name = mb_convert_encoding($first_name, "HTML-ENTITIES", "UTF-8"); 
Спасибо за ответ, проблема была в том, что я не добавил & quot; Accept-кодировка = & Quot; UTF-8 & Quot; & Quot; в виде. Zoran Đukić
Я попробовал это, и это не так. echo $ first_name; // print & # xE1; & # xE1; & # xE1; & # xE1; & # xE1; & # xE1; b & # xE9; & # xE9; & # xE9; & # xE9; & # xE9; & # xE9; & # xE9 б & # x161; & # x161; & # x161; & # x161; $ first_name = mb_convert_encoding ($ first_name, & quot; HTML-ENTITIES & quot ;, & quot; UTF-8 & quot;); echo $ first_name; // print & # xE1; & # xE1; & # xE1; & # xE1; & # xE1; & # xE1; b & # xE9; & # xE9; & # xE9; & # xE9; & # xE9; & # xE9; & # xE9 б & # x161; & # x161; & # x161; & # x161; Zoran Đukić
19

что следует отбросить, а что заменить. Вот как я сейчас это делаю.

$string = 'À some string with junk Ĩ Ä ';

$replace = [
    '&lt;' => '', '&gt;' => '', '&#039;' => '', '&amp;' => '',
    '&quot;' => '', 'À' => 'A', 'Á' => 'A', 'Â' => 'A', 'Ã' => 'A', 'Ä' => 'Ae',
    '&Auml;' => 'A', 'Å' => 'A', 'Ā' => 'A', 'Ą' => 'A', 'Ă' => 'A', 'Æ' => 'Ae',
    'Ç' => 'C', 'Ć' => 'C', 'Č' => 'C', 'Ĉ' => 'C', 'Ċ' => 'C', 'Ď' => 'D', 'Đ' => 'D',
    'Ð' => 'D', 'È' => 'E', 'É' => 'E', 'Ê' => 'E', 'Ë' => 'E', 'Ē' => 'E',
    'Ę' => 'E', 'Ě' => 'E', 'Ĕ' => 'E', 'Ė' => 'E', 'Ĝ' => 'G', 'Ğ' => 'G',
    'Ġ' => 'G', 'Ģ' => 'G', 'Ĥ' => 'H', 'Ħ' => 'H', 'Ì' => 'I', 'Í' => 'I',
    'Î' => 'I', 'Ï' => 'I', 'Ī' => 'I', 'Ĩ' => 'I', 'Ĭ' => 'I', 'Į' => 'I',
    'İ' => 'I', 'IJ' => 'IJ', 'Ĵ' => 'J', 'Ķ' => 'K', 'Ł' => 'K', 'Ľ' => 'K',
    'Ĺ' => 'K', 'Ļ' => 'K', 'Ŀ' => 'K', 'Ñ' => 'N', 'Ń' => 'N', 'Ň' => 'N',
    'Ņ' => 'N', 'Ŋ' => 'N', 'Ò' => 'O', 'Ó' => 'O', 'Ô' => 'O', 'Õ' => 'O',
    'Ö' => 'Oe', '&Ouml;' => 'Oe', 'Ø' => 'O', 'Ō' => 'O', 'Ő' => 'O', 'Ŏ' => 'O',
    'Œ' => 'OE', 'Ŕ' => 'R', 'Ř' => 'R', 'Ŗ' => 'R', 'Ś' => 'S', 'Š' => 'S',
    'Ş' => 'S', 'Ŝ' => 'S', 'Ș' => 'S', 'Ť' => 'T', 'Ţ' => 'T', 'Ŧ' => 'T',
    'Ț' => 'T', 'Ù' => 'U', 'Ú' => 'U', 'Û' => 'U', 'Ü' => 'Ue', 'Ū' => 'U',
    '&Uuml;' => 'Ue', 'Ů' => 'U', 'Ű' => 'U', 'Ŭ' => 'U', 'Ũ' => 'U', 'Ų' => 'U',
    'Ŵ' => 'W', 'Ý' => 'Y', 'Ŷ' => 'Y', 'Ÿ' => 'Y', 'Ź' => 'Z', 'Ž' => 'Z',
    'Ż' => 'Z', 'Þ' => 'T', 'à' => 'a', 'á' => 'a', 'â' => 'a', 'ã' => 'a',
    'ä' => 'ae', '&auml;' => 'ae', 'å' => 'a', 'ā' => 'a', 'ą' => 'a', 'ă' => 'a',
    'æ' => 'ae', 'ç' => 'c', 'ć' => 'c', 'č' => 'c', 'ĉ' => 'c', 'ċ' => 'c',
    'ď' => 'd', 'đ' => 'd', 'ð' => 'd', 'è' => 'e', 'é' => 'e', 'ê' => 'e',
    'ë' => 'e', 'ē' => 'e', 'ę' => 'e', 'ě' => 'e', 'ĕ' => 'e', 'ė' => 'e',
    'ƒ' => 'f', 'ĝ' => 'g', 'ğ' => 'g', 'ġ' => 'g', 'ģ' => 'g', 'ĥ' => 'h',
    'ħ' => 'h', 'ì' => 'i', 'í' => 'i', 'î' => 'i', 'ï' => 'i', 'ī' => 'i',
    'ĩ' => 'i', 'ĭ' => 'i', 'į' => 'i', 'ı' => 'i', 'ij' => 'ij', 'ĵ' => 'j',
    'ķ' => 'k', 'ĸ' => 'k', 'ł' => 'l', 'ľ' => 'l', 'ĺ' => 'l', 'ļ' => 'l',
    'ŀ' => 'l', 'ñ' => 'n', 'ń' => 'n', 'ň' => 'n', 'ņ' => 'n', 'ʼn' => 'n',
    'ŋ' => 'n', 'ò' => 'o', 'ó' => 'o', 'ô' => 'o', 'õ' => 'o', 'ö' => 'oe',
    '&ouml;' => 'oe', 'ø' => 'o', 'ō' => 'o', 'ő' => 'o', 'ŏ' => 'o', 'œ' => 'oe',
    'ŕ' => 'r', 'ř' => 'r', 'ŗ' => 'r', 'š' => 's', 'ù' => 'u', 'ú' => 'u',
    'û' => 'u', 'ü' => 'ue', 'ū' => 'u', '&uuml;' => 'ue', 'ů' => 'u', 'ű' => 'u',
    'ŭ' => 'u', 'ũ' => 'u', 'ų' => 'u', 'ŵ' => 'w', 'ý' => 'y', 'ÿ' => 'y',
    'ŷ' => 'y', 'ž' => 'z', 'ż' => 'z', 'ź' => 'z', 'þ' => 't', 'ß' => 'ss',
    'ſ' => 'ss', 'ый' => 'iy', 'А' => 'A', 'Б' => 'B', 'В' => 'V', 'Г' => 'G',
    'Д' => 'D', 'Е' => 'E', 'Ё' => 'YO', 'Ж' => 'ZH', 'З' => 'Z', 'И' => 'I',
    'Й' => 'Y', 'К' => 'K', 'Л' => 'L', 'М' => 'M', 'Н' => 'N', 'О' => 'O',
    'П' => 'P', 'Р' => 'R', 'С' => 'S', 'Т' => 'T', 'У' => 'U', 'Ф' => 'F',
    'Х' => 'H', 'Ц' => 'C', 'Ч' => 'CH', 'Ш' => 'SH', 'Щ' => 'SCH', 'Ъ' => '',
    'Ы' => 'Y', 'Ь' => '', 'Э' => 'E', 'Ю' => 'YU', 'Я' => 'YA', 'а' => 'a',
    'б' => 'b', 'в' => 'v', &apos,;г' => 'g', 'д' => 'd', 'е' => 'e', 'ё' => 'yo',
    'ж' => 'zh', 'з' => 'z', 'и' => 'i', 'й' => 'y', 'к' => 'k', 'л' => 'l',
    'м' => 'm', 'н' => 'n', 'о' => 'o', 'п' => 'p', 'р' => 'r', 'с' => 's',
    'т' => 't', 'у' => 'u', 'ф' => 'f', 'х' => 'h', 'ц' => 'c', 'ч' => 'ch',
    'ш' => 'sh', 'щ' => 'sch', 'ъ' => '', 'ы' => 'y', 'ь' => '', 'э' => 'e',
    'ю' => 'yu', 'я' => 'ya'
];

echo str_replace(array_keys($replace), $replace, $string);  
68

iconv - из заметок пользователя, кажется, это то, что вы хотите сделать:транслитерация символов

// PHP.net User notes
<?php
    $string = "ʿABBĀSĀBĀD";

    echo iconv('UTF-8', 'ISO-8859-1//TRANSLIT', $string);
    // output: [nothing, and you get a notice]

    echo iconv('UTF-8', 'ISO-8859-1//IGNORE', $string);
    // output: ABBSBD

    echo iconv('UTF-8', 'ISO-8859-1//TRANSLIT//IGNORE', $string);
    // output: ABBASABAD
    // Yay! That's what I wanted!
?>

Бытьvery conscientious с вашими кодировками символов, так что вы сохраняете одинаковую кодировку на всех этапах процесса - внешний интерфейс, отправка форм, кодировка исходных файлов. Кодировка по умолчанию в PHP и в формах - ISO-8859-1, до PHP 5.4, где она изменилась на UTF8 (наконец-то!).

Есть пара функций, с которыми вы можете поиграть для идей. Первый из класса инфлектора CakePHP, называемыйslug:

public static function slug($string, $replacement = '_') {
    $quotedReplacement = preg_quote($replacement, '/');

    $merge = array(
        '/[^\s\p{Ll}\p{Lm}\p{Lo}\p{Lt}\p{Lu}\p{Nd}]/mu' => ' ',
        '/\\s+/' => $replacement,
        sprintf('/^[%s]+|[%s]+$/', $quotedReplacement, $quotedReplacement) => '',
    );

    $map = self::$_transliteration + $merge;
    return preg_replace(array_keys($map), array_values($map), $string);
}

Это зависит отself::$_transliteration массив, который похож на то, что вы делали в своем вопросе - вы можетесм. источник для инфлектора на GitHub.

Еще одна функция, которую я использую лично, котораяприходит отсюда.

function slugify($text,$strict = false) {
    $text = html_entity_decode($text, ENT_QUOTES, 'UTF-8');
    // replace non letter or digits by -
    $text = preg_replace('~[^\\pL\d.]+~u', '-', $text);

    // trim
    $text = trim($text, '-');
    setlocale(LC_CTYPE, 'en_GB.utf8');
    // transliterate
    if (function_exists('iconv')) {
        $text = iconv('utf-8', 'us-ascii//TRANSLIT', $text);
    }

    // lowercase
    $text = strtolower($text);
    // remove unwanted characters
    $text = preg_replace('~[^-\w.]+~', '', $text);
    if (empty($text)) {
        return 'empty_

Эти функции выполняют транслитерацию и создание & apos;слизни& APOS; от произвольного ввода текста, что очень полезно при создании веб-приложений. Надеюсь это поможет!

; } if ($strict) { $text = str_replace(".", "_", $text); } return $text; }

Эти функции выполняют транслитерацию и создание & apos;слизни& APOS; от произвольного ввода текста, что очень полезно при создании веб-приложений. Надеюсь это поможет!

Я продолжал использовать свою функцию, потому что с ее помощью я могу точно определить, какой буквой я заменю какую-либо букву. Zoran Đukić
Я потратил впустую так много времени, но этот код работал на меня :) спасибо большое !!
добро пожаловать, я полагаю, что все эти функции не были действительно нужны :), но также можно посмотреть.
Спасибо за ответ, проблема была в том, что я не добавил & quot; Accept-кодировка = & Quot; UTF-8 & Quot; & Quot; в виде. Zoran Đukić
Есть ли в любом случае сохранение & # xE5; & # xE4; & # xF6 ;?

Похожие вопросы