TextInfo.ToTitleCase(String) Метод

Определение

Меняет регистр заданной строки на верхний (за исключением слов полностью в верхнем регистре, которые считаются сокращениями).Converts the specified string to title case (except for words that are entirely in uppercase, which are considered to be acronyms).

public:
 System::String ^ ToTitleCase(System::String ^ str);
public string ToTitleCase (string str);
member this.ToTitleCase : string -> string
Public Function ToTitleCase (str As String) As String

Параметры

str
String

Строка для преобразования в верхний регистр.The string to convert to title case.

Возвраты

Заданная строка, преобразуемая в заглавные символы.The specified string converted to title case.

Исключения

strnull.str is null.

Примеры

В следующем примере изменяется регистр строки на основе языка и региональных параметров "Английский (США)" с именем языка и региональных параметров en-US.The following example changes the casing of a string based on the English (United States) culture, with the culture name en-US.

using namespace System;
using namespace System::Globalization;
int main()
{
   
   // Defines the String* with mixed casing.
   String^ myString = "wAr aNd pEaCe";
   
   // Creates a TextInfo based on the S"en-US" culture.
   CultureInfo^ MyCI = gcnew CultureInfo( "en-US",false );
   TextInfo^ myTI = MyCI->TextInfo;
   
   // Changes a String* to lowercase.
   Console::WriteLine( "\"{0}\" to lowercase: {1}", myString, myTI->ToLower( myString ) );
   
   // Changes a String* to uppercase.
   Console::WriteLine( "\"{0}\" to uppercase: {1}", myString, myTI->ToUpper( myString ) );
   
   // Changes a String* to titlecase.
   Console::WriteLine( "\"{0}\" to titlecase: {1}", myString, myTI->ToTitleCase( myString ) );
}

/*
This code produces the following output.

S"wAr aNd pEaCe" to lowercase: war and peace
S"wAr aNd pEaCe" to uppercase: WAR AND PEACE
S"wAr aNd pEaCe" to titlecase: War And Peace

*/
using System;
using System.Globalization;


public class SamplesTextInfo  {

   public static void Main()  {

      // Defines the string with mixed casing.
      string myString = "wAr aNd pEaCe";

      // Creates a TextInfo based on the "en-US" culture.
      TextInfo myTI = new CultureInfo("en-US",false).TextInfo;

      // Changes a string to lowercase.
      Console.WriteLine( "\"{0}\" to lowercase: {1}", myString, myTI.ToLower( myString ) );

      // Changes a string to uppercase.
      Console.WriteLine( "\"{0}\" to uppercase: {1}", myString, myTI.ToUpper( myString ) );

      // Changes a string to titlecase.
      Console.WriteLine( "\"{0}\" to titlecase: {1}", myString, myTI.ToTitleCase( myString ) );

   }

}

/*
This code produces the following output.

"wAr aNd pEaCe" to lowercase: war and peace
"wAr aNd pEaCe" to uppercase: WAR AND PEACE
"wAr aNd pEaCe" to titlecase: War And Peace

*/
Imports System.Globalization

Public Class SamplesTextInfo

   Public Shared Sub Main()

      ' Defines the string with mixed casing.
      Dim myString As String = "wAr aNd pEaCe"

      ' Creates a TextInfo based on the "en-US" culture.
      Dim myTI As TextInfo = New CultureInfo("en-US", False).TextInfo

      ' Changes a string to lowercase.
      Console.WriteLine("""{0}"" to lowercase: {1}", myString, myTI.ToLower(myString))

      ' Changes a string to uppercase.
      Console.WriteLine("""{0}"" to uppercase: {1}", myString, myTI.ToUpper(myString))

      ' Changes a string to titlecase.
      Console.WriteLine("""{0}"" to titlecase: {1}", myString, myTI.ToTitleCase(myString))

   End Sub

End Class


'This code produces the following output.
'
'"wAr aNd pEaCe" to lowercase: war and peace
'"wAr aNd pEaCe" to uppercase: WAR AND PEACE
'"wAr aNd pEaCe" to titlecase: War And Peace


В примере ниже каждая строка из массива передается в метод ToTitleCase.The following example passes each string in an array to the ToTitleCase method. Среди строк есть как строки заголовков, так и сокращения.The strings include proper title strings as well as acronyms. Строки преобразуются в регистр заголовка с использованием соглашений языка и региональных параметров en-US.The strings are converted to title case by using the conventions of the en-US culture.

using System;
using System.Globalization;

public class Example
{
   public static void Main()
   {
      string[] values = { "a tale of two cities", "gROWL to the rescue",
                          "inside the US government", "sports and MLB baseball",
                          "The Return of Sherlock Holmes", "UNICEF and children"};
                                 
      TextInfo ti = CultureInfo.CurrentCulture.TextInfo;
      foreach (var value in values)
         Console.WriteLine("{0} --> {1}", value, ti.ToTitleCase(value));
   }
}
// The example displays the following output:
//    a tale of two cities --> A Tale Of Two Cities
//    gROWL to the rescue --> Growl To The Rescue
//    inside the US government --> Inside The US Government
//    sports and MLB baseball --> Sports And MLB Baseball
//    The Return of Sherlock Holmes --> The Return Of Sherlock Holmes
//    UNICEF and children --> UNICEF And Children
Imports System.Globalization

Module Example
   Public Sub Main()
      Dim values() As String = { "a tale of two cities", "gROWL to the rescue",
                                 "inside the US government", "sports and MLB baseball",
                                 "The Return of Sherlock Holmes", "UNICEF and children"}
                                 
      Dim ti As TextInfo = CultureInfo.CurrentCulture.TextInfo
      For Each value In values
         Console.WriteLine("{0} --> {1}", value, ti.ToTitleCase(value))
      Next
   End Sub
End Module
' The example displays the following output:
'    a tale of two cities --> A Tale Of Two Cities
'    gROWL to the rescue --> Growl To The Rescue
'    inside the US government --> Inside The US Government
'    sports and MLB baseball --> Sports And MLB Baseball
'    The Return of Sherlock Holmes --> The Return Of Sherlock Holmes
'    UNICEF and children --> UNICEF And Children

Комментарии

Как правило, регистр заголовка преобразует первый символ слова в верхний регистр, а остальные символы — в нижний регистр.Generally, title casing converts the first character of a word to uppercase and the rest of the characters to lowercase. Однако в настоящее время этот метод не предоставляет правильный регистр для преобразования слова, которое является полностью прописным, например акронимом.However, this method does not currently provide proper casing to convert a word that is entirely uppercase, such as an acronym. В следующей таблице показано, как метод отображает несколько строк.The following table shows the way the method renders several strings.

Входные данныеInput ЯзыкLanguage Ожидаемый результатExpected result Фактический результатActual result
War-и мираwar and peace АнглийскийEnglish War-и мираWar and Peace War-и мираWar And Peace
На анхалтер дурч кристалл ГалаксисPer anhalter durch die Galaxis НемецкийGerman На Анхалтер дурч кристалл ГалаксисPer Anhalter durch die Galaxis На Анхалтер Дурч кристалл ГалаксисPer Anhalter Durch Die Galaxis
Les науфрагéс д'исакles naufragés d'ythaq ФранцузскийFrench Les Науфрагéс Д'исакLes Naufragés d'Ythaq Les Науфрагéс Д'исакLes Naufragés D'ythaq

Как показано выше, ToTitleCase метод предоставляет произвольное поведение регистра, которое не обязательно лингвистическо правильно.As illustrated above, the ToTitleCase method provides an arbitrary casing behavior which is not necessarily linguistically correct. Для лингвистического правильного решения потребуются дополнительные правила, и текущий алгоритм будет несколько проще и быстрее.A linguistically correct solution would require additional rules, and the current algorithm is somewhat simpler and faster. Мы оставляем за собой право сделать этот API медленнее в будущем.We reserve the right to make this API slower in the future.

Текущая реализация ToTitleCase метода возвращает выходную строку, которая имеет ту же длину, что и входная строка.The current implementation of the ToTitleCase method yields an output string that is the same length as the input string. Однако это поведение не гарантируется и может измениться в будущих реализациях.However, this behavior is not guaranteed and could change in a future implementation.

Применяется к

Дополнительно