Nota
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare ad accedere o modificare le directory.
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare a modificare le directory.
Suggerimento
Questo articolo fa parte della sezione Nozioni fondamentali per gli sviluppatori che già conoscono almeno un linguaggio di programmazione e stanno imparando C#. Se non si ha familiarità con la programmazione, iniziare prima con le esercitazioni introduttive .
Venire da un'altra lingua? L'interpolazione di stringhe in C# funziona in modo molto simile ai valori letterali modello in JavaScript (`${x}`) o alle stringhe f in Python (f"{x}"). L'espressione all'interno {} può essere qualsiasi espressione C# valida ed è possibile aggiungere identificatori di formato e allineamento senza uscire dalla stringa.
L'interpolazione di stringhe consente di inserire espressioni direttamente in un valore letterale di stringa anteponendo $ al valore letterale:
double a = 3;
double b = 4;
Console.WriteLine($"Area of the right triangle with legs of {a} and {b} is {0.5 * a * b}");
Console.WriteLine($"Length of the hypotenuse of the right triangle with legs of {a} and {b} is {CalculateHypotenuse(a, b)}");
double CalculateHypotenuse(double leg1, double leg2) => Math.Sqrt(leg1 * leg1 + leg2 * leg2);
// => Area of the right triangle with legs of 3 and 4 is 6
// => Length of the hypotenuse of the right triangle with legs of 3 and 4 is 5
Ogni { } è un'espressione di interpolazione. C# valuta l'espressione, converte il risultato in una stringa chiamando il relativo ToString() metodo e sostituisce il testo nel risultato. L'interpolazione di stringhe per un'espressione null è la stringa vuota. Nella maggior parte dei casi, la conversione predefinita produce l'output desiderato e non è necessario eseguire altre operazioni.
Le stringhe interpolate sono un'alternativa più leggibile a String.Formate supportano il set di funzionalità di formattazione composita completo. Tutto ciò che è possibile fare con una stringa di formato posizionale classica, ovvero identificatori di formato, allineamento, formattazione compatibile con le impostazioni cultura e stringhe costanti, è anche possibile eseguire con una stringa interpolata. Il resto di questo articolo illustra queste opzioni. Contattali solo quando hai bisogno di un controllo più corretto sul risultato; in caso contrario, la forma normale $"{expression}" è sufficiente.
Per il trattamento di riferimento al linguaggio della sintassi e dei tipi di gestore sottostanti, vedere riferimento alle stringhe interpolate . Per argomenti incentrati sulle prestazioni, ad Span<char> esempio interpolazione e gestori di stringhe interpolati personalizzati, vedere Operazioni sulle stringhe.
Applicare una stringa di formato
Per controllare la formattazione del risultato di un'espressione, seguire l'espressione con due punti e una stringa di formato standard o personalizzata:
{<expression>:<formatString>}
L'esempio seguente formatta un valore DateTime e un valore Double:
var date = new DateTime(1731, 11, 25);
Console.WriteLine($"On {date:dddd, MMMM dd, yyyy} L. Euler introduced the letter e to denote {Math.E:F5}.");
// => On Sunday, November 25, 1731 L. Euler introduced the letter e to denote 2.71828.
Impostare la larghezza e l'allineamento del campo
Per produrre un output allineato, seguire l'espressione con una virgola e una larghezza minima del campo. Le larghezze positive allineano il valore a destra, mentre le larghezze negative lo allineano a sinistra:
{<expression>,<width>}
var titles = new Dictionary<string, string>()
{
["Doyle, Arthur Conan"] = "Hound of the Baskervilles, The",
["London, Jack"] = "Call of the Wild, The",
["Shakespeare, William"] = "Tempest, The"
};
Console.WriteLine("Author and Title List");
Console.WriteLine();
Console.WriteLine($"|{"Author",-25}|{"Title",30}|");
foreach (var title in titles)
{
Console.WriteLine($"|{title.Key,-25}|{title.Value,30}|");
}
// => Author and Title List
// =>
// => |Author | Title|
// => |Doyle, Arthur Conan |Hound of the Baskervilles, The|
// => |London, Jack | Call of the Wild, The|
// => |Shakespeare, William | Tempest, The|
Quando sono necessari sia l'allineamento che una stringa di formato, inserire prima l'allineamento:
{<expression>,<width>:<formatString>}
const int NameAlignment = -9;
const int ValueAlignment = 7;
double a = 3;
double b = 4;
Console.WriteLine($"Three classical Pythagorean means of {a} and {b}:");
Console.WriteLine($"|{"Arithmetic",NameAlignment}|{0.5 * (a + b),ValueAlignment:F3}|");
Console.WriteLine($"|{"Geometric",NameAlignment}|{Math.Sqrt(a * b),ValueAlignment:F3}|");
Console.WriteLine($"|{"Harmonic",NameAlignment}|{2 / (1 / a + 1 / b),ValueAlignment:F3}|");
// => Three classical Pythagorean means of 3 and 4:
// => |Arithmetic| 3.500|
// => |Geometric| 3.464|
// => |Harmonic | 3.429|
Se il valore formattato è maggiore della larghezza richiesta, C# ignora la larghezza e genera il valore completo.
Eseguire l'escape delle parentesi graffe e usare sequenze di escape
Le stringhe interpolate supportano le stesse sequenze di escape dei letterali di stringa ordinari. Per includere nel risultato il carattere letterale { o }, raddoppiarlo ({{ o }}).
Per i percorsi e le altre stringhe che contengono barre rovesciate, preferire una stringa letterale non elaborata con interpolazione ($"""...""") rispetto alla precedente forma verbatim ($@"..."). I letterali di stringa non elaborati non elaborano le sequenze di escape, quindi le barre rovesciate vengono visualizzate così come sono:
int[] xs = [1, 2, 7, 9];
int[] ys = [7, 9, 12];
Console.WriteLine($"Find the intersection of the {{{string.Join(", ", xs)}}} and {{{string.Join(", ", ys)}}} sets.");
// => Find the intersection of the {1, 2, 7, 9} and {7, 9, 12} sets.
var userName = "Jane";
var stringWithEscapes = $"C:\\Users\\{userName}\\Documents";
var rawInterpolated = $"""C:\Users\{userName}\Documents""";
Console.WriteLine(stringWithEscapes);
Console.WriteLine(rawInterpolated);
// => C:\Users\Jane\Documents
// => C:\Users\Jane\Documents
Usare un'espressione condizionale
I due punti hanno un significato speciale all'interno di un'espressione di interpolazione, quindi racchiudi un'espressione condizionale tra parentesi:
var rand = new Random(42);
for (int i = 0; i < 3; i++)
{
Console.WriteLine($"Coin flip: {(rand.NextDouble() < 0.5 ? "heads" : "tails")}");
}
Estendere un'espressione su più righe
Per una migliore leggibilità, interrompere espressioni di interpolazione lunghe tra più righe. Le espressioni di interpolazione a più righe sono disponibili a partire da C# 11. Nell'esempio seguente vengono aggiunte nuove righe tra i { caratteri e } per separare le espressioni interpolate dal testo letterale:
int[] numbers = [3, 1, 4, 1, 5, 9, 2, 6];
Console.WriteLine($"Total: {
numbers.Sum()
}, average: {numbers.Average():F2}.");
// => Total: 31, average: 3.88.
Compilare stringhe costanti
È possibile creare stringhe interpolate costanti quando ogni espressione interpolata è un valore costante. Questo le rende utilizzabili come argomenti di attributo, modelli switch e in altri contesti che richiedono costanti in fase di compilazione:
const string Audience = "world";
const string Greeting = $"Hello, {Audience}!";
Console.WriteLine(Greeting);
// => Hello, world!
Formatta con una cultura specifica
Per impostazione predefinita, una stringa interpolata formatta i valori usando CultureInfo.CurrentCulture, che influisce sulle rappresentazioni di data, numero e valuta. Per un output deterministico, specifica una cultura esplicita in String.Create(IFormatProvider, DefaultInterpolatedStringHandler):
CultureInfo[] cultures =
[
CultureInfo.GetCultureInfo("en-US"),
CultureInfo.GetCultureInfo("en-GB"),
CultureInfo.GetCultureInfo("nl-NL"),
CultureInfo.InvariantCulture
];
var date = new DateTime(2026, 5, 21, 12, 35, 31);
var number = 31_415_926.536;
foreach (var culture in cultures)
{
var cultureSpecificMessage = string.Create(culture, $"{date,23}{number,20:N3}");
Console.WriteLine($"{culture.Name,-10}{cultureSpecificMessage}");
}
// Output is similar to:
// => en-US 5/21/2026 12:35:31 PM 31,415,926.536
// => en-GB 21/05/2026 12:35:31 31,415,926.536
// => nl-NL 21-05-2026 12:35:31 31.415.926,536
// => 05/21/2026 12:35:31 31,415,926.536
Per l'output invariante (log, formati di file, dati leggibili dal computer), passare CultureInfo.InvariantCulture:
var timestamp = new DateTime(2026, 5, 21, 15, 46, 24);
string message = string.Create(CultureInfo.InvariantCulture, $"Date and time in invariant culture: {timestamp}");
Console.WriteLine(message);
// => Date and time in invariant culture: 05/21/2026 15:46:24