c# list - Case insensitive 'Contains (string)'




12 Answers

Per verificare se il paragraph stringa contiene la word stringa (grazie @QuarterMeister)

culture.CompareInfo.IndexOf(paragraph, word, CompareOptions.IgnoreCase) >= 0

Dove culture è l'istanza di CultureInfo descrive la lingua in cui è scritto il testo.

Questa soluzione è trasparente sulla definizione di insensibilità alle maiuscole e minuscole, che dipende dalla lingua . Ad esempio, la lingua inglese utilizza i caratteri I e i per le versioni maiuscole e minuscole della nona lettera, mentre la lingua turca usa questi caratteri per l' undicesima e la dodicesima lettera dell'alfabeto lungo 29 lettere. La versione turca di "i" è il carattere non familiare "©".

Quindi le stringhe tin e TIN sono la stessa parola in inglese , ma diverse parole in turco . Come ho capito, uno significa "spirito" e l'altro è una parola onomatopeica. (Turchi, per favore correggimi se sbaglio o suggerisci un esempio migliore)

Per riassumere, puoi solo rispondere alla domanda "queste due stringhe sono le stesse ma in diversi casi" se sai in che lingua si trova il testo . Se non lo sai, dovrai prendere un punt. Data l'egemonia inglese nel software, dovresti probabilmente ricorrere a CultureInfo.InvariantCulture , perché sarà sbagliato in modi familiari.

vb net

C'è un modo per rendere il seguente ritorno vero?

string title = "ASTRINGTOTEST";
title.Contains("string");

Non sembra esserci un sovraccarico che mi permetta di impostare la distinzione tra maiuscole e minuscole. Attualmente li UPPERCASE entrambi, ma questo è semplicemente sciocco (con cui mi riferisco ai problemi i18n che hanno un involucro alto e basso).

AGGIORNARE
Questa domanda è antica e da allora mi sono reso conto che ho chiesto una risposta semplice per un argomento davvero vasto e difficile se ti interessa investigarlo completamente.
Per la maggior parte dei casi, in base al codice in lingua inglese, this risposta sarà sufficiente. Sospetto che la maggior parte della gente che viene qui cada in questa categoria è la risposta più popolare.
This risposta, tuttavia, fa emergere il problema intrinseco che non possiamo confrontare il maiuscolo / minuscolo del testo fino a quando non sappiamo che entrambi i testi sono la stessa cultura e sappiamo che cos'è questa cultura. Questa è forse una risposta meno popolare, ma penso che sia più corretta ed è per questo che l'ho contrassegnata come tale.




Puoi usare IndexOf() questo modo:

string title = "STRING";

if (title.IndexOf("string", 0, StringComparison.CurrentCultureIgnoreCase) != -1)
{
    // The string exists in the original
}

Poiché 0 (zero) può essere un indice, si controlla contro -1.

MSDN

La posizione dell'indice di valore a base zero se tale stringa viene trovata o -1 se non lo è. Se value è String.Empty, il valore restituito è 0.




Puoi sempre alzare o abbassare le stringhe prima.

string title = "string":
title.ToUpper().Contains("STRING")  // returns true

Oops, ho appena visto quell'ultima parte. Un confronto senza distinzione tra maiuscole e minuscole avrebbe * probabilmente * lo stesso effetto, e se le prestazioni non sono un problema, non vedo un problema con la creazione di copie maiuscole e il confronto di quelle. Potrei giurare che una volta ho visto un confronto insensibile al caso ...




La classe StringExtension è la soluzione da seguire, ho combinato un paio di post sopra per dare un esempio di codice completo:

public static class StringExtensions
{
    /// <summary>
    /// Allows case insensitive checks
    /// </summary>
    public static bool Contains(this string source, string toCheck, StringComparison comp)
    {
        return source.IndexOf(toCheck, comp) >= 0;
    }
}



OrdinalIgnoreCase, CurrentCultureIgnoreCase o InvariantCultureIgnoreCase?

Poiché questo manca, ecco alcuni consigli su quando utilizzare quale:

dos

  • Usa StringComparison.OrdinalIgnoreCase per i confronti come predefinito sicuro per la corrispondenza stringa indipendente dalla cultura.
  • Usa confronti StringComparison.OrdinalIgnoreCase per aumentare la velocità.
  • Utilizzare le operazioni stringa StringComparison.CurrentCulture-based quando si visualizza l'output per l'utente.
  • Cambiare l'uso corrente delle operazioni stringa sulla base della cultura invariabile per utilizzare StringComparison.Ordinal o StringComparison.OrdinalIgnoreCase non linguistico quando il confronto è
    linguisticamente irrilevante (simbolico, per esempio).
  • Utilizzare ToUpperInvariant anziché ToLowerInvariant durante la normalizzazione delle stringhe per il confronto.

cosa non fare

  • Utilizzare gli overload per le operazioni sulle stringhe che non specificano esplicitamente o implicitamente il meccanismo di comparazione delle stringhe.
  • Usa stringa StringComparison.InvariantCulture
    operazioni nella maggior parte dei casi; una delle poche eccezioni sarebbe
    persistenti dati linguisticamente significativi ma culturalmente-agnostici.

Sulla base di queste regole dovresti usare:

string title = "STRING";
if (title.IndexOf("string", 0, StringComparison.[YourDecision]) != -1)
{
    // The string exists in the original
}

mentre [YourDecision] dipende dalle raccomandazioni di cui sopra.

collegamento di origine: http://msdn.microsoft.com/en-us/library/ms973919.aspx




Il metodo InStr dall'assembly VisualBasic è il migliore se si ha una preoccupazione per l'internazionalizzazione (o si potrebbe reimplementarla). Guardando in esso, dotNeetPeek mostra che non solo tiene conto di maiuscole e minuscole, ma anche di caratteri kana e di caratteri pieni e semi-larghi (principalmente rilevanti per le lingue asiatiche, sebbene ci siano anche versioni a larghezza intera dell'alfabeto romano) ). Sto saltando alcuni dettagli, ma controlla il metodo privato InternalInStrText :

private static int InternalInStrText(int lStartPos, string sSrc, string sFind)
{
  int num = sSrc == null ? 0 : sSrc.Length;
  if (lStartPos > num || num == 0)
    return -1;
  if (sFind == null || sFind.Length == 0)
    return lStartPos;
  else
    return Utils.GetCultureInfo().CompareInfo.IndexOf(sSrc, sFind, lStartPos, CompareOptions.IgnoreCase | CompareOptions.IgnoreKanaType | CompareOptions.IgnoreWidth);
}



Usa questo:

string.Compare("string", "STRING", new System.Globalization.CultureInfo("en-US"), System.Globalization.CompareOptions.IgnoreCase);



L'uso di una RegEx è un modo semplice per farlo:

Regex.IsMatch(title, "string", RegexOptions.IgnoreCase);



Queste sono le soluzioni più facili.

  1. Per indice di

    string title = "STRING";
    
    if (title.IndexOf("string", 0, StringComparison.CurrentCultureIgnoreCase) != -1)
    {
        // contains 
    }
    
  2. Cambiando caso

    string title = "STRING";
    
    bool contains = title.ToLower().Contains("string")
    
  3. Di Regex

    Regex.IsMatch(title, "string", RegexOptions.IgnoreCase);
    



È possibile utilizzare la funzione string.indexof () . Questo sarà case insensitive




Solo .NET Core 2.0+ (al momento)

.NET Core ha avuto un paio di metodi per risolvere questo problema dalla versione 2.0:

  • String.Contains (Char, StringComparison )
  • String.Contains (String, StringComparison )

Esempio:

"Test".Contains("test", System.StringComparison.CurrentCultureIgnoreCase);

Col tempo, probabilmente si faranno strada nello standard .NET e, da lì, in tutte le altre implementazioni della Base Class Library.




se si desidera verificare se la stringa passata è in stringa, esiste un metodo semplice.

string yourStringForCheck= "abc";
string stringInWhichWeCheck= "Test abc abc";

bool isContaines = stringInWhichWeCheck.ToLower().IndexOf(yourStringForCheck.ToLower()) > -1;

This boolean value will return if string contains or not



Related

c# string contains case-insensitive