Сделайте первую букву в верхнем регистре, а остальные строчные в строке

Все, Я пытаюсь вставить фамилию в базу данных. Я хотел бы, чтобы первое письмо было заглавным для имени, и если у них есть два последних имени, запишите их первое и второе имена. Например, если кто-то входит:

имя фамилии maidenname

Он преобразует это в Marriedname Maidenname и так далее, если будет более двух имен. Другой сценарий заключается в том, что у кого-то есть апостроф в их имени, так что все равно это делается, если кто-то входит:

О'Коннелл

Это нужно будет преобразовать в O'Connell. Я использовал:

ucfirst(strtolower($last_name));

Однако, как вы можете сказать, это не сработало бы во всех сценариях. Спасибо за любой совет!

Ответ 1

Это будет использовать все буквы первого слова и буквы сразу после апострофа. Он сделает все остальные буквы строчными. Он должен работать для вас:

str_replace('\' ', '\'', ucwords(str_replace('\'', '\' ', strtolower($last_name))));

Ответ 2

Ни один из них не является UTF8 дружественным, поэтому здесь, который работает безупречно (до сих пор)

function titleCase($string, $delimiters = array(" ", "-", ".", "'", "O'", "Mc"), $exceptions = array("and", "to", "of", "das", "dos", "I", "II", "III", "IV", "V", "VI"))
{
    /*
     * Exceptions in lower case are words you don't want converted
     * Exceptions all in upper case are any words you don't want converted to title case
     *   but should be converted to upper case, e.g.:
     *   king henry viii or king henry Viii should be King Henry VIII
     */
    $string = mb_convert_case($string, MB_CASE_TITLE, "UTF-8");
    foreach ($delimiters as $dlnr => $delimiter) {
        $words = explode($delimiter, $string);
        $newwords = array();
        foreach ($words as $wordnr => $word) {
            if (in_array(mb_strtoupper($word, "UTF-8"), $exceptions)) {
                // check exceptions list for any words that should be in upper case
                $word = mb_strtoupper($word, "UTF-8");
            } elseif (in_array(mb_strtolower($word, "UTF-8"), $exceptions)) {
                // check exceptions list for any words that should be in upper case
                $word = mb_strtolower($word, "UTF-8");
            } elseif (!in_array($word, $exceptions)) {
                // convert to uppercase (non-utf8 only)
                $word = ucfirst($word);
            }
            array_push($newwords, $word);
        }
        $string = join($delimiter, $newwords);
   }//foreach
   return $string;
}

Использование:

$s = 'SÃO JOÃO DOS SANTOS';
$v = titleCase($s); // 'São João dos Santos' 

Ответ 3

вы можете попробовать это для слова

<?php echo ucwords(strtolower('Dhaka, JAMALPUR, sarishabari')) ?>

результат: Dhaka, Jamalpur, Sarishabari

Ответ 4

Используйте эту встроенную функцию:

ucwords('string');

Ответ 5

Я не верю, что будет один хороший ответ, который охватывает все сценарии для вас. Форум PHP.net для ucwords имеет массу дискуссий, но ни у кого нет ответа для всех. Я бы рекомендовал вам стандартизировать либо использование прописных букв, либо выход из пользовательского ввода.

Ответ 6

Вы можете использовать preg_replace с флагом e (выполнить функцию php):

function processReplacement($one, $two)
{
  return $one . strtoupper($two);
}

$name = "bob o'conner";
$name = preg_replace("/(^|[^a-zA-Z])([a-z])/e","processReplacement('$1', '$2')", $name);

var_dump($name); // output "Bob O'Conner"

Возможно, шаблон регулярного выражения может быть улучшен, но я сделал следующее:

  • $1 - это либо начало строки, либо любой неалфавитный символ.
  • $2 - любой строчный алфавитный символ

Затем мы заменяем оба из них результатом простой функции processReplacement().

Если у вас есть PHP 5.3, вероятно, стоит сделать processReplacement() анонимной функцией.

Ответ 7

Это немного более простой и более прямой ответ на главный вопрос. функция ниже подражает подходам PHP. На всякий случай, если PHP расширит это с помощью своих пространств имен в будущем, сначала проверяется тест. Im использую это доказательство воды для любых языков в моих установках wordpress.

$str = mb_ucfirst($str, 'UTF-8', true);

Это делает первую букву в верхнем регистре, а все остальные строчные буквы - Q. Если для третьего arg установлено значение false (по умолчанию), остальная часть строки не обрабатывается.

// Extends PHP
if (!function_exists('mb_ucfirst')) {

function mb_ucfirst($str, $encoding = "UTF-8", $lower_str_end = false) {
    $first_letter = mb_strtoupper(mb_substr($str, 0, 1, $encoding), $encoding);
    $str_end = "";
    if ($lower_str_end) {
        $str_end = mb_strtolower(mb_substr($str, 1, mb_strlen($str, $encoding), $encoding), $encoding);
    } else {
        $str_end = mb_substr($str, 1, mb_strlen($str, $encoding), $encoding);
    }
    $str = $first_letter . $str_end;
    return $str;
}

}

/Лундман

Ответ 8

Сначала преобразуйте в заголовок, затем найдите первый апостроф и запишите верхний символ NEXT. Вам нужно будет добавить много проверок, чтобы после апострофа был char, и этот код будет работать только на одном апострофе. например "Мэри О'Каллахан О'коннелл".

$str = mb_convert_case($str, MB_CASE_TITLE, "UTF-8");
$pos = strpos($str, "'");
if ($pos != FALSE)
{
     $str[$pos+1] = strtoupper($str[$pos+1]);
}

Ответ 9

используйте ucfirst(strtolower($var));