Path.ChangeExtension(String, String) Metodo

Definizione

Cambia l'estensione di una stringa di percorso.Changes the extension of a path string.

public:
 static System::String ^ ChangeExtension(System::String ^ path, System::String ^ extension);
public static string ChangeExtension (string path, string extension);
static member ChangeExtension : string * string -> string
Public Shared Function ChangeExtension (path As String, extension As String) As String

Parametri

path
String

Informazioni sul percorso da modificare.The path information to modify. Il percorso non può contenere i caratteri definiti in GetInvalidPathChars().The path cannot contain any of the characters defined in GetInvalidPathChars().

extension
String

Nuova estensione, con o senza un punto iniziale.The new extension (with or without a leading period). Specificare null per rimuovere un'estensione esistente da path.Specify null to remove an existing extension from path.

Restituisce

Informazioni sul percorso modificato.The modified path information.

Nelle piattaforme desktop basate su Windows, se path è null o una stringa vuota (""), le informazioni sul percorso verranno restituite immutate.On Windows-based desktop platforms, if path is null or an empty string (""), the path information is returned unmodified. Se extension è null, la stringa restituita conterrà il percorso specificato senza estensione.If extension is null, the returned string contains the specified path with its extension removed. Se path non ha estensione e extension non è null, la stringa di percorso restituita conterrà extension alla fine di path.If path has no extension, and extension is not null, the returned path string contains extension appended to the end of path.

Eccezioni

path contiene uno o più dei caratteri non validi definiti nel metodo GetInvalidPathChars().path contains one or more of the invalid characters defined in GetInvalidPathChars().

Esempi

Nell'esempio seguente viene illustrato l'utilizzo del metodo ChangeExtension.The following example demonstrates a use of the ChangeExtension method.

#using <system.dll>

using namespace System;
using namespace System::IO;
void ChangeExtension()
{
   String^ goodFileName = "C:\\mydir\\myfile.com.extension";
   String^ badFileName = "C:\\mydir\\";
   String^ result;
   result = Path::ChangeExtension( goodFileName,  ".old" );
   Console::WriteLine( "ChangeExtension({0}, '.old') returns '{1}'", goodFileName, result );
   result = Path::ChangeExtension( goodFileName,  "" );
   Console::WriteLine( "ChangeExtension({0}, '') returns '{1}'", goodFileName, result );
   result = Path::ChangeExtension( badFileName,  ".old" );
   Console::WriteLine( "ChangeExtension({0}, '.old') returns '{1}'", badFileName, result );
   
   // This code produces output similar to the following:
   //
   // ChangeExtension(C:\mydir\myfile.com.extension, '.old') returns 'C:\mydir\myfile.com.old'
   // ChangeExtension(C:\mydir\myfile.com.extension, '') returns 'C:\mydir\myfile.com.'
   // ChangeExtension(C:\mydir\, '.old') returns 'C:\mydir\.old'
using System;
using System.IO;

public class PathSnippets
{

    public void ChangeExtension()
    {
        string goodFileName = @"C:\mydir\myfile.com.extension";
        string badFileName = @"C:\mydir\";
        string result;

        result = Path.ChangeExtension(goodFileName, ".old");
        Console.WriteLine("ChangeExtension({0}, '.old') returns '{1}'",
            goodFileName, result); 

        result = Path.ChangeExtension(goodFileName, "");
        Console.WriteLine("ChangeExtension({0}, '') returns '{1}'", 
            goodFileName, result); 

        result = Path.ChangeExtension(badFileName, ".old");
        Console.WriteLine("ChangeExtension({0}, '.old') returns '{1}'", 
            badFileName, result); 

        // This code produces output similar to the following:
        //
        // ChangeExtension(C:\mydir\myfile.com.extension, '.old') returns 'C:\mydir\myfile.com.old'
        // ChangeExtension(C:\mydir\myfile.com.extension, '') returns 'C:\mydir\myfile.com.'
        // ChangeExtension(C:\mydir\, '.old') returns 'C:\mydir\.old'
Imports System.IO

Public Class PathSnippets
    Public Sub ChangeExtension()
        Dim goodFileName As String = "C:\mydir\myfile.com.extension"
        Dim badFileName As String = "C:\mydir\"
        Dim result As String
        result = Path.ChangeExtension(goodFileName, ".old")
        Console.WriteLine("ChangeExtension({0}, '.old') returns '{1}'", goodFileName, result)
        result = Path.ChangeExtension(goodFileName, "")
        Console.WriteLine("ChangeExtension({0}, '') returns '{1}'", goodFileName, result)
        result = Path.ChangeExtension(badFileName, ".old")
        Console.WriteLine("ChangeExtension({0}, '.old') returns '{1}'", badFileName, result)

        ' This code produces output similar to the following:
        '
        ' ChangeExtension(C:\mydir\myfile.com.extension, '.old') returns 'C:\mydir\myfile.com.old'
        ' ChangeExtension(C:\mydir\myfile.com.extension, '') returns 'C:\mydir\myfile.com.'
        ' ChangeExtension(C:\mydir\, '.old') returns 'C:\mydir\.old'

Commenti

Se nessuna delle due pathextension contiene un punto (.), ChangeExtension aggiunge il punto.If neither path nor extension contains a period (.), ChangeExtension adds the period.

Il parametro extension può contenere più punti ed eventuali caratteri di percorso validi e può essere di qualsiasi lunghezza.The extension parameter can contain multiple periods and any valid path characters, and can be any length. Se extension è null, la stringa restituita contiene il contenuto di path con l'ultimo periodo e tutti i caratteri che lo seguono.If extension is null, the returned string contains the contents of path with the last period and all characters following it removed.

Se extension è una stringa vuota, la stringa di percorso restituita conterrà il contenuto di path con i caratteri successivi all'ultimo periodo rimosso.If extension is an empty string, the returned path string contains the contents of path with any characters following the last period removed.

Se path non dispone di un'estensione e extension non è null, la stringa restituita conterrà path seguito da extension.If path does not have an extension and extension is not null, the returned string contains path followed by extension.

Se extension non è null e non contiene un punto di primo livello, viene aggiunto il punto.If extension is not null and does not contain a leading period, the period is added.

Se path contiene un'estensione multipla separata da più punti, la stringa restituita conterrà il contenuto di path con l'ultimo periodo e tutti i caratteri successivi sostituiti da extension.If path contains a multiple extension separated by multiple periods, the returned string contains the contents of path with the last period and all characters following it replaced by extension. Se, ad esempio, path è "\Dir1\examples\pathtests.CSX.txt" e extension è "CS", il percorso modificato è "\Dir1\examples\pathtests.CSX.cs".For example, if path is "\Dir1\examples\pathtests.csx.txt" and extension is "cs", the modified path is "\Dir1\examples\pathtests.csx.cs".

Non è possibile verificare che i risultati restituiti siano validi in tutti gli scenari.It is not possible to verify that the returned results are valid in all scenarios. Se, ad esempio, path è vuoto, viene accodato extension.For example, if path is empty, extension is appended.

Per un elenco delle attività di I/O comuni, vedere attività di i/o comuni.For a list of common I/O tasks, see Common I/O Tasks.

Si applica a

Vedi anche