文字列の最初の文字を大文字にして残りの文字を下げる簡単な方法はありますか?組み込みのメソッドはありますか、それとも自分で作成する必要がありますか?
17 に答える
TextInfo.ToTitleCase()
文字列の各トークンの最初の文字を大文字にします。
頭字語の大文字を維持する必要がない場合は、を含める必要がありますToLower()
。
string s = "JOHN DOE";
s = CultureInfo.CurrentCulture.TextInfo.ToTitleCase(s.ToLower());
// Produces "John Doe"
CurrentCultureが利用できない場合は、次を使用します。
string s = "JOHN DOE";
s = new System.Globalization.CultureInfo("en-US", false).TextInfo.ToTitleCase(s.ToLower());
詳細な説明については、MSDNリンクを参照してください。
CultureInfo.CurrentCulture.TextInfo.ToTitleCase("hello world");
String test = "HELLO HOW ARE YOU";
string s = CultureInfo.CurrentCulture.TextInfo.ToTitleCase(test);
上記のコードは機能しません.....
したがって、以下のコードを下に変換して入力し、関数を適用します
String test = "HELLO HOW ARE YOU";
string s = CultureInfo.CurrentCulture.TextInfo.ToTitleCase(test.ToLower());
CultureInfo.CurrentCulture.TextInfo.ToTitleCase
たとえば、アポストロフィーなど、処理できない場合があります'
。
string input = CultureInfo.CurrentCulture.TextInfo.ToTitleCase("o'reilly, m'grego, d'angelo");
// input = O'reilly, M'grego, D'angelo
正規表現\b[a-zA-Z]
を使用して、単語境界の後の単語の開始文字を識別することもできます。その場合、メソッド\b
のおかげで、一致を大文字の等価物に置き換えるだけで済みます。Regex.Replace(string input,string pattern,MatchEvaluator evaluator)
string input = "o'reilly, m'grego, d'angelo";
input = Regex.Replace(input.ToLower(), @"\b[a-zA-Z]", m => m.Value.ToUpper());
// input = O'Reilly, M'Grego, D'Angelo
正規表現は、必要に応じて調整できます。たとえば、正規表現が次のようになるケースを処理MacDonald
したい場合などです。McFry
(?<=\b(?:mc|mac)?)[a-zA-Z]
string input = "o'reilly, m'grego, d'angelo, macdonald's, mcfry";
input = Regex.Replace(input.ToLower(), @"(?<=\b(?:mc|mac)?)[a-zA-Z]", m => m.Value.ToUpper());
// input = O'Reilly, M'Grego, D'Angelo, MacDonald'S, McFry
より多くの接頭辞を処理する必要がある場合は(?:mc|mac)
、たとえばフランス語の接頭辞を追加するなど、グループを変更するだけdu, de
です(?:mc|mac|du|de)
。
最後に、この正規表現MacDonald'S
も最後のケースに一致する's
ことがわかるので、正規表現で否定的な後ろ向きで処理する必要があります(?<!'s\b)
。最後に:
string input = "o'reilly, m'grego, d'angelo, macdonald's, mcfry";
input = Regex.Replace(input.ToLower(), @"(?<=\b(?:mc|mac)?)[a-zA-Z](?<!'s\b)", m => m.Value.ToUpper());
// input = O'Reilly, M'Grego, D'Angelo, MacDonald's, McFry
Mc と Mac は、米国全体で一般的な姓の接頭辞であり、他にもあります。TextInfo.ToTitleCase はこれらのケースを処理しないため、この目的には使用しないでください。これが私がやっている方法です:
public static string ToTitleCase(string str)
{
string result = str;
if (!string.IsNullOrEmpty(str))
{
var words = str.Split(' ');
for (int index = 0; index < words.Length; index++)
{
var s = words[index];
if (s.Length > 0)
{
words[index] = s[0].ToString().ToUpper() + s.Substring(1);
}
}
result = string.Join(" ", words);
}
return result;
}
ToTitleCase()が機能するはずです。
最も直接的なオプションは、.NETで使用可能なToTitleCase関数を使用することです。この関数は、ほとんどの場合、名前を処理する必要があります。edgが指摘したように、機能しない名前がいくつかありますが、これらはかなりまれなので、そのような名前が一般的な文化をターゲットにしている場合を除いて、あまり心配する必要はありません。
ただし、.NET言語を使用していない場合は、入力がどのように表示されるかによって異なります。名前と名前に2つの別々のフィールドがある場合は、最初の文字を大文字にして、残りの文字を下に使用することができます。サブストリング。
firstName = firstName.Substring(0, 1).ToUpper() + firstName.Substring(1).ToLower();
lastName = lastName.Substring(0, 1).ToUpper() + lastName.Substring(1).ToLower();
ただし、同じ文字列の一部として複数の名前が提供されている場合は、情報を取得する方法を把握し、それに応じて情報を分割する必要があります。したがって、「John Doe」のような名前を取得している場合は、スペース文字に基づいて文字列を分割します。「Doe、John」などの形式の場合は、カンマに基づいて分割する必要があります。ただし、分割したら、前に示したコードを適用するだけです。
これを修正するには、独自の方法を使用します。
たとえば、「hello world.hello this is the stackoverflow world.」というフレーズです。「Hello World. Hello This Is The Stackoverflow World.」になります。正規表現 \b (単語の開始) \w (単語の最初の文字) でうまくいきます。
/// <summary>
/// Makes each first letter of a word uppercase. The rest will be lowercase
/// </summary>
/// <param name="Phrase"></param>
/// <returns></returns>
public static string FormatWordsWithFirstCapital(string Phrase)
{
MatchCollection Matches = Regex.Matches(Phrase, "\\b\\w");
Phrase = Phrase.ToLower();
foreach (Match Match in Matches)
Phrase = Phrase.Remove(Match.Index, 1).Insert(Match.Index, Match.Value.ToUpper());
return Phrase;
}
CultureInfo.CurrentCulture.TextInfo.ToTitleCase ("私の名前");
戻ります ~ 私の名前
しかし、前述のように、McFly のような名前にはまだ問題があります。
このクラスはトリックを行います。_prefixes静的文字列配列に新しいプレフィックスを追加できます。
public static class StringExtensions
{
public static string ToProperCase( this string original )
{
if( String.IsNullOrEmpty( original ) )
return original;
string result = _properNameRx.Replace( original.ToLower( CultureInfo.CurrentCulture ), HandleWord );
return result;
}
public static string WordToProperCase( this string word )
{
if( String.IsNullOrEmpty( word ) )
return word;
if( word.Length > 1 )
return Char.ToUpper( word[0], CultureInfo.CurrentCulture ) + word.Substring( 1 );
return word.ToUpper( CultureInfo.CurrentCulture );
}
private static readonly Regex _properNameRx = new Regex( @"\b(\w+)\b" );
private static readonly string[] _prefixes = {
"mc"
};
private static string HandleWord( Match m )
{
string word = m.Groups[1].Value;
foreach( string prefix in _prefixes )
{
if( word.StartsWith( prefix, StringComparison.CurrentCultureIgnoreCase ) )
return prefix.WordToProperCase() + word.Substring( prefix.Length ).WordToProperCase();
}
return word.WordToProperCase();
}
}
ToTitleCase を使用するという提案は、すべて大文字の文字列では機能しません。したがって、最初の文字で ToUpper を呼び出し、残りの文字で ToLower を呼び出す必要があります。
vS2k8 を使用している場合は、拡張メソッドを使用して String クラスに追加できます。
public static string FirstLetterToUpper(this String input)
{
return input = input.Substring(0, 1).ToUpper() +
input.Substring(1, input.Length - 1);
}
これがお役に立てば幸いです。
String fName = "firstname";
String lName = "lastname";
String capitalizedFName = CultureInfo.CurrentCulture.TextInfo.ToTitleCase(fName);
String capitalizedLName = CultureInfo.CurrentCulture.TextInfo.ToTitleCase(lName);
public static string ConvertToCaptilize(string input)
{
if (!string.IsNullOrEmpty(input))
{
string[] arrUserInput = input.Split(' ');
// Initialize a string builder object for the output
StringBuilder sbOutPut = new StringBuilder();
// Loop thru each character in the string array
foreach (string str in arrUserInput)
{
if (!string.IsNullOrEmpty(str))
{
var charArray = str.ToCharArray();
int k = 0;
foreach (var cr in charArray)
{
char c;
c = k == 0 ? char.ToUpper(cr) : char.ToLower(cr);
sbOutPut.Append(c);
k++;
}
}
sbOutPut.Append(" ");
}
return sbOutPut.ToString();
}
return string.Empty;
}
強調表示された問題/問題のいくつかを回避するには、最初に文字列を小文字に変換してから、ToTitleCase メソッドを呼び出すことをお勧めします。次に、IndexOf(" Mc") または IndexOf(" O\'") を使用して、より具体的な注意が必要な特殊なケースを判断できます。
inputString = inputString.ToLower();
inputString = CultureInfo.CurrentCulture.TextInfo.ToTitleCase(inputString);
int indexOfMc = inputString.IndexOf(" Mc");
if(indexOfMc > 0)
{
inputString.Substring(0, indexOfMc + 3) + inputString[indexOfMc + 3].ToString().ToUpper() + inputString.Substring(indexOfMc + 4);
}
私はこの方法が好きです:
using System.Globalization;
...
TextInfo myTi = new CultureInfo("en-Us",false).TextInfo;
string raw = "THIS IS ALL CAPS";
string firstCapOnly = myTi.ToTitleCase(raw.ToLower());
このMSDN の記事から引用。
edg が示したように、特別な名前を処理するには、より複雑なアルゴリズムが必要になります (これが、多くの場所ですべてを大文字に強制する理由です)。
このテストされていない c# のようなものは、要求した単純なケースを処理する必要があります。
public string SentenceCase(string input)
{
return input(0, 1).ToUpper + input.Substring(1).ToLower;
}