जवाबों:
ToUpper
वर्तमान संस्कृति का उपयोग करता है। ToUpperInvariant
अपरिवर्तनीय संस्कृति का उपयोग करता है।
विहित उदाहरण तुर्की है, जहां "i" का ऊपरी मामला "I" नहीं है।
नमूना कोड अंतर दिखा रहा है:
using System;
using System.Drawing;
using System.Globalization;
using System.Threading;
using System.Windows.Forms;
public class Test
{
[STAThread]
static void Main()
{
string invariant = "iii".ToUpperInvariant();
CultureInfo turkey = new CultureInfo("tr-TR");
Thread.CurrentThread.CurrentCulture = turkey;
string cultured = "iii".ToUpper();
Font bigFont = new Font("Arial", 40);
Form f = new Form {
Controls = {
new Label { Text = invariant, Location = new Point(20, 20),
Font = bigFont, AutoSize = true},
new Label { Text = cultured, Location = new Point(20, 100),
Font = bigFont, AutoSize = true }
}
};
Application.Run(f);
}
}
तुर्की के बारे में अधिक जानने के लिए, इस तुर्की टेस्ट ब्लॉग पोस्ट को देखें ।
मुझे यह सुनकर हैरानी नहीं होगी कि अभिलिखित चरित्रों के इर्द-गिर्द कई अन्य बड़े पूंजीकरण के मुद्दे हैं। यह सिर्फ एक उदाहरण है जिसे मैं अपने सिर के ऊपर से जानता हूं ... आंशिक रूप से क्योंकि यह मुझे सालों पहले जावा, जहां मैं ऊपरी था एक स्ट्रिंग को भरना और उसकी तुलना "मेल" से करना। तुर्की में इतना अच्छा काम नहीं किया ...
ımage
लिए एक फ़ील्ड नाम के रूप में सुझाव दे रहा हूं । ऐसा लगता है कि कभी-कभी Microsoft भी तुर्की परीक्षा में असफल हो जाता है, एक पीसी की भाषा भी तुर्की नहीं है, बस योग्य है। Image
Unable to find key name that matches 'rıght'
जॉन का जवाब एकदम सही है। मैं बस जोड़ना चाहता था जो ToUpperInvariant
कॉलिंग के समान है ToUpper(CultureInfo.InvariantCulture)
।
यह जॉन के उदाहरण को थोड़ा सरल बनाता है:
using System;
using System.Drawing;
using System.Globalization;
using System.Threading;
using System.Windows.Forms;
public class Test
{
[STAThread]
static void Main()
{
string invariant = "iii".ToUpper(CultureInfo.InvariantCulture);
string cultured = "iii".ToUpper(new CultureInfo("tr-TR"));
Application.Run(new Form {
Font = new Font("Times New Roman", 40),
Controls = {
new Label { Text = invariant, Location = new Point(20, 20), AutoSize = true },
new Label { Text = cultured, Location = new Point(20, 100), AutoSize = true },
}
});
}
}
मैंने न्यू टाइम्स रोमन का भी उपयोग किया क्योंकि यह एक कूलर फ़ॉन्ट है।
मैं भी सेट Form
के Font
दो के बजाय संपत्ति Label
क्योंकि नियंत्रण Font
संपत्ति विरासत में मिला है।
और मैंने कुछ अन्य पंक्तियों को सिर्फ इसलिए कम कर दिया क्योंकि मुझे कॉम्पैक्ट (उदाहरण, उत्पादन नहीं) कोड पसंद है।
मेरे पास इस समय करने के लिए कुछ भी बेहतर नहीं था।
MSDN से प्रारंभ करें
http://msdn.microsoft.com/en-us/library/system.string.toupperinvariant.aspx
ToUpperInvariant विधि ToUpper (CultureInfo.InvariantCulture) के बराबर है
सिर्फ इसलिए कि एक पूंजी मैं है 'मैं' अंग्रेजी में, हमेशा ऐसा नहीं है।
String.ToUpper
और String.ToLower
अलग-अलग संस्कृतियों को देखते हुए अलग-अलग परिणाम दे सकते हैं। सबसे ज्ञात उदाहरण तुर्की उदाहरण है , जिसके लिए लोअरकेस लैटिन "i" को अपरकेस में बदलना, एक पूंजीगत लैटिन "I" में परिणाम नहीं करता है, लेकिन तुर्की "I" में।
जैसा कि मेरे लिए यह उपरोक्त चित्र ( स्रोत ) के साथ भी भ्रामक था , मैंने तुर्की उदाहरण के लिए सटीक आउटपुट देखने के लिए एक कार्यक्रम (नीचे स्रोत कोड देखें) लिखा था:
# Lowercase letters
Character | UpperInvariant | UpperTurkish | LowerInvariant | LowerTurkish
English i - i (\u0069) | I (\u0049) | I (\u0130) | i (\u0069) | i (\u0069)
Turkish i - ı (\u0131) | ı (\u0131) | I (\u0049) | ı (\u0131) | ı (\u0131)
# Uppercase letters
Character | UpperInvariant | UpperTurkish | LowerInvariant | LowerTurkish
English i - I (\u0049) | I (\u0049) | I (\u0049) | i (\u0069) | ı (\u0131)
Turkish i - I (\u0130) | I (\u0130) | I (\u0130) | I (\u0130) | i (\u0069)
जैसा कि आप देख सकते हैं:
Culture.CultureInvariant
के रूप में तुर्की अक्षर छोड़ देता हैToUpper
और ToLower
प्रतिवर्ती होते हैं, जो कि एक वर्ण को अपरकेस करने के बाद उतारा जाता है, उसे मूल रूप में लाता है, जब तक कि दोनों ऑपरेशनों के लिए एक ही संस्कृति का उपयोग नहीं किया जाता।MSDN के अनुसार , Char.ToUpper और Char.ToLower तुर्की और Azeri के लिए केवल प्रभावित संस्कृतियाँ हैं क्योंकि वे एकल-वर्ण आवरण अंतर वाले एकमात्र हैं। स्ट्रिंग्स के लिए, अधिक संस्कृतियां प्रभावित हो सकती हैं।
आउटपुट उत्पन्न करने के लिए उपयोग किए जाने वाले कंसोल एप्लिकेशन का स्रोत कोड:
using System;
using System.Globalization;
using System.Linq;
using System.Text;
namespace TurkishI
{
class Program
{
static void Main(string[] args)
{
var englishI = new UnicodeCharacter('\u0069', "English i");
var turkishI = new UnicodeCharacter('\u0131', "Turkish i");
Console.WriteLine("# Lowercase letters");
Console.WriteLine("Character | UpperInvariant | UpperTurkish | LowerInvariant | LowerTurkish");
WriteUpperToConsole(englishI);
WriteLowerToConsole(turkishI);
Console.WriteLine("\n# Uppercase letters");
var uppercaseEnglishI = new UnicodeCharacter('\u0049', "English i");
var uppercaseTurkishI = new UnicodeCharacter('\u0130', "Turkish i");
Console.WriteLine("Character | UpperInvariant | UpperTurkish | LowerInvariant | LowerTurkish");
WriteLowerToConsole(uppercaseEnglishI);
WriteLowerToConsole(uppercaseTurkishI);
Console.ReadKey();
}
static void WriteUpperToConsole(UnicodeCharacter character)
{
Console.WriteLine("{0,-9} - {1,10} | {2,-14} | {3,-12} | {4,-14} | {5,-12}",
character.Description,
character,
character.UpperInvariant,
character.UpperTurkish,
character.LowerInvariant,
character.LowerTurkish
);
}
static void WriteLowerToConsole(UnicodeCharacter character)
{
Console.WriteLine("{0,-9} - {1,10} | {2,-14} | {3,-12} | {4,-14} | {5,-12}",
character.Description,
character,
character.UpperInvariant,
character.UpperTurkish,
character.LowerInvariant,
character.LowerTurkish
);
}
}
class UnicodeCharacter
{
public static readonly CultureInfo TurkishCulture = new CultureInfo("tr-TR");
public char Character { get; }
public string Description { get; }
public UnicodeCharacter(char character) : this(character, string.Empty) { }
public UnicodeCharacter(char character, string description)
{
if (description == null) {
throw new ArgumentNullException(nameof(description));
}
Character = character;
Description = description;
}
public string EscapeSequence => ToUnicodeEscapeSequence(Character);
public UnicodeCharacter LowerInvariant => new UnicodeCharacter(Char.ToLowerInvariant(Character));
public UnicodeCharacter UpperInvariant => new UnicodeCharacter(Char.ToUpperInvariant(Character));
public UnicodeCharacter LowerTurkish => new UnicodeCharacter(Char.ToLower(Character, TurkishCulture));
public UnicodeCharacter UpperTurkish => new UnicodeCharacter(Char.ToUpper(Character, TurkishCulture));
private static string ToUnicodeEscapeSequence(char character)
{
var bytes = Encoding.Unicode.GetBytes(new[] {character});
var prefix = bytes.Length == 4 ? @"\U" : @"\u";
var hex = BitConverter.ToString(bytes.Reverse().ToArray()).Replace("-", string.Empty);
return $"{prefix}{hex}";
}
public override string ToString()
{
return $"{Character} ({EscapeSequence})";
}
}
}
अंग्रेजी में कोई अंतर नहीं है। केवल तुर्की संस्कृति में एक अंतर पाया जा सकता है।