ZipFileExtensions.CreateEntryFromFile Metodo

Definizione

Archivia un file comprimendolo e aggiungendolo all'archivio ZIP.Archives a file by compressing it and adding it to the zip archive.

Overload

CreateEntryFromFile(ZipArchive, String, String)

Archivia un file comprimendolo e aggiungendolo all'archivio ZIP.Archives a file by compressing it and adding it to the zip archive.

CreateEntryFromFile(ZipArchive, String, String, CompressionLevel)

Archivia un file comprimendolo con il livello di compressione specificato e aggiungendolo all'archivio ZIP.Archives a file by compressing it using the specified compression level and adding it to the zip archive.

CreateEntryFromFile(ZipArchive, String, String)

Archivia un file comprimendolo e aggiungendolo all'archivio ZIP.Archives a file by compressing it and adding it to the zip archive.

public:
[System::Runtime::CompilerServices::Extension]
 static System::IO::Compression::ZipArchiveEntry ^ CreateEntryFromFile(System::IO::Compression::ZipArchive ^ destination, System::String ^ sourceFileName, System::String ^ entryName);
public static System.IO.Compression.ZipArchiveEntry CreateEntryFromFile (this System.IO.Compression.ZipArchive destination, string sourceFileName, string entryName);
static member CreateEntryFromFile : System.IO.Compression.ZipArchive * string * string -> System.IO.Compression.ZipArchiveEntry
<Extension()>
Public Function CreateEntryFromFile (destination As ZipArchive, sourceFileName As String, entryName As String) As ZipArchiveEntry

Parametri

destination
ZipArchive

Archivio ZIP a cui aggiungere il file.The zip archive to add the file to.

sourceFileName
String

Percorso del file da archiviare.The path to the file to be archived. È possibile specificare un percorso assoluto o un percorso relativo.You can specify either a relative or an absolute path. Un percorso relativo è interpretato rispetto alla directory di lavoro corrente.A relative path is interpreted as relative to the current working directory.

entryName
String

Nome della voce da creare nell'archivio ZIP.The name of the entry to create in the zip archive.

Restituisce

Wrapper per la nuova voce nell'archivio ZIP.A wrapper for the new entry in the zip archive.

Eccezioni

sourceFileName è Empty, contiene solo spazi vuoti oppure contiene almeno un carattere non valido.sourceFileName is Empty, contains only white space, or contains at least one invalid character.

-oppure--or- entryName è Empty.entryName is Empty.

sourceFileName o entryName è null.sourceFileName or entryName is null.

In sourceFileName, il percorso specificato, il nome file o entrambi superano la lunghezza massima definita dal sistema.In sourceFileName, the specified path, file name, or both exceed the system-defined maximum length.

sourceFileName non è valido (ad esempio si trova in un'unità non mappata).sourceFileName is invalid (for example, it is on an unmapped drive).

Il file specificato da sourceFileName non può essere aperto o è troppo grande per essere aggiornato (il limite corrente è pari a MaxValue).The file specified by sourceFileName cannot be opened, or is too large to be updated (current limit is MaxValue).

sourceFileName specifica una directory.sourceFileName specifies a directory.

-oppure--or- Il chiamante non dispone dell'autorizzazione richiesta per accedere al file specificato da sourceFileName.The caller does not have the required permission to access the file specified by sourceFileName.

Il file specificato da sourceFileName non è stato trovato.The file specified by sourceFileName is not found.

Il formato del parametro sourceFileName non è valido.The sourceFileName parameter is in an invalid format.

-oppure--or- L'archivio ZIP non supporta la scrittura.The zip archive does not support writing.

L'archivio ZIP è stato eliminato.The zip archive has been disposed.

Esempi

Nell'esempio seguente viene illustrato come creare una nuova voce in un archivio zip da un file esistente.The following example shows how to create a new entry in a zip archive from an existing file.

using System;
using System.IO;
using System.IO.Compression;

namespace ConsoleApplication
{
    class Program
    {
        static void Main(string[] args)
        {
            string zipPath = @"c:\users\exampleuser\start.zip";
            string extractPath = @"c:\users\exampleuser\extract";
            string newFile = @"c:\users\exampleuser\NewFile.txt";
            
            using (ZipArchive archive = ZipFile.Open(zipPath, ZipArchiveMode.Update))
            {
                archive.CreateEntryFromFile(newFile, "NewEntry.txt");
                archive.ExtractToDirectory(extractPath);
            } 
        }
    }
}
Imports System.IO
Imports System.IO.Compression

Module Module1

    Sub Main()
        Dim zipPath As String = "c:\users\exampleuser\end.zip"
        Dim extractPath As String = "c:\users\exampleuser\extract"
        Dim newFile As String = "c:\users\exampleuser\NewFile.txt"

        Using archive As ZipArchive = ZipFile.Open(zipPath, ZipArchiveMode.Update)
            archive.CreateEntryFromFile(newFile, "NewEntry.txt", CompressionLevel.Fastest)
            archive.ExtractToDirectory(extractPath)
        End Using
    End Sub

End Module

Commenti

La nuova voce nell'archivio contiene il contenuto del file specificato da sourceFileName.The new entry in the archive contains the contents of the file specified by sourceFileName. Se nell'archivio esiste già una voce con il nome specificato (entryName), viene creata una seconda voce con un nome identico.If an entry with the specified name (entryName) already exists in the archive, a second entry is created with an identical name. La LastWriteTime proprietà della voce è impostata sull'ultima volta in cui il file nel file system è stato modificato.The LastWriteTime property of the entry is set to the last time the file on the file system was changed.

Quando ZipArchiveMode.Update è presente, il limite di dimensioni di una voce è limitato a Int32.MaxValue.When ZipArchiveMode.Update is present, the size limit of an entry is limited to Int32.MaxValue. Questo limite è dovuto al fatto che la modalità di aggiornamento usa un MemoryStream internamente per consentire la richiesta di ricerca durante l'aggiornamento di un archivio e MemoryStream ha un valore massimo uguale alla dimensione di un valore int.This limit is because update mode uses a MemoryStream internally to allow the seeking required when updating an archive, and MemoryStream has a maximum equal to the size of an int.

CreateEntryFromFile(ZipArchive, String, String, CompressionLevel)

Archivia un file comprimendolo con il livello di compressione specificato e aggiungendolo all'archivio ZIP.Archives a file by compressing it using the specified compression level and adding it to the zip archive.

public:
[System::Runtime::CompilerServices::Extension]
 static System::IO::Compression::ZipArchiveEntry ^ CreateEntryFromFile(System::IO::Compression::ZipArchive ^ destination, System::String ^ sourceFileName, System::String ^ entryName, System::IO::Compression::CompressionLevel compressionLevel);
public static System.IO.Compression.ZipArchiveEntry CreateEntryFromFile (this System.IO.Compression.ZipArchive destination, string sourceFileName, string entryName, System.IO.Compression.CompressionLevel compressionLevel);
static member CreateEntryFromFile : System.IO.Compression.ZipArchive * string * string * System.IO.Compression.CompressionLevel -> System.IO.Compression.ZipArchiveEntry

Parametri

destination
ZipArchive

Archivio ZIP a cui aggiungere il file.The zip archive to add the file to.

sourceFileName
String

Percorso del file da archiviare.The path to the file to be archived. È possibile specificare un percorso assoluto o un percorso relativo.You can specify either a relative or an absolute path. Un percorso relativo è interpretato rispetto alla directory di lavoro corrente.A relative path is interpreted as relative to the current working directory.

entryName
String

Nome della voce da creare nell'archivio ZIP.The name of the entry to create in the zip archive.

compressionLevel
CompressionLevel

Uno dei valori di enumerazione che indica se privilegiare la velocità o l'efficacia di compressione quando si crea la voce.One of the enumeration values that indicates whether to emphasize speed or compression effectiveness when creating the entry.

Restituisce

Wrapper per la nuova voce nell'archivio ZIP.A wrapper for the new entry in the zip archive.

Eccezioni

sourceFileName è Empty, contiene solo spazi vuoti oppure contiene almeno un carattere non valido.sourceFileName is Empty, contains only white space, or contains at least one invalid character.

-oppure--or- entryName è Empty.entryName is Empty.

sourceFileName o entryName è null.sourceFileName or entryName is null.

sourceFileName non è valido (ad esempio si trova in un'unità non mappata).sourceFileName is invalid (for example, it is on an unmapped drive).

In sourceFileName, il percorso specificato, il nome file o entrambi superano la lunghezza massima definita dal sistema.In sourceFileName, the specified path, file name, or both exceed the system-defined maximum length.

Il file specificato da sourceFileName non può essere aperto o è troppo grande per essere aggiornato (il limite corrente è pari a MaxValue).The file specified by sourceFileName cannot be opened, or is too large to be updated (current limit is MaxValue).

sourceFileName specifica una directory.sourceFileName specifies a directory.

-oppure--or- Il chiamante non dispone dell'autorizzazione richiesta per accedere al file specificato da sourceFileName.The caller does not have the required permission to access the file specified by sourceFileName.

Il file specificato da sourceFileName non è stato trovato.The file specified by sourceFileName is not found.

Il formato del parametro sourceFileName non è valido.The sourceFileName parameter is in an invalid format.

-oppure--or- L'archivio ZIP non supporta la scrittura.The zip archive does not support writing.

L'archivio ZIP è stato eliminato.The zip archive has been disposed.

Esempi

Nell'esempio seguente viene illustrato come creare una nuova voce in un archivio zip da un file esistente e come specificare il livello di compressione.The following example shows how to create a new entry in a zip archive from an existing file, and specify the compression level.

using System;
using System.IO;
using System.IO.Compression;

namespace ConsoleApplication
{
    class Program
    {
        static void Main(string[] args)
        {
            string zipPath = @"c:\users\exampleuser\start.zip";
            string extractPath = @"c:\users\exampleuser\extract";
            string newFile = @"c:\users\exampleuser\NewFile.txt";
            
            using (ZipArchive archive = ZipFile.Open(zipPath, ZipArchiveMode.Update))
            {
                archive.CreateEntryFromFile(newFile, "NewEntry.txt", CompressionLevel.Fastest);
                archive.ExtractToDirectory(extractPath);
            } 
        }
    }
}
Imports System.IO
Imports System.IO.Compression

Module Module1

    Sub Main()
        Dim zipPath As String = "c:\users\exampleuser\end.zip"
        Dim extractPath As String = "c:\users\exampleuser\extract"
        Dim newFile As String = "c:\users\exampleuser\NewFile.txt"

        Using archive As ZipArchive = ZipFile.Open(zipPath, ZipArchiveMode.Update)
            archive.CreateEntryFromFile(newFile, "NewEntry.txt", CompressionLevel.Fastest)
            archive.ExtractToDirectory(extractPath)
        End Using
    End Sub

End Module

Commenti

La nuova voce nell'archivio contiene il contenuto del file specificato da sourceFileName.The new entry in the archive contains the contents of the file specified by sourceFileName. Se nell'archivio esiste già una voce con il nome specificato (entryName), viene creata una seconda voce con un nome identico.If an entry with the specified name (entryName) already exists in the archive, a second entry is created with an identical name. La LastWriteTime proprietà della voce è impostata sull'ultima volta in cui il file nel file system è stato modificato.The LastWriteTime property of the entry is set to the last time the file on the file system was changed.

Quando ZipArchiveMode.Update è presente, il limite di dimensioni di una voce è limitato a Int32.MaxValue.When ZipArchiveMode.Update is present, the size limit of an entry is limited to Int32.MaxValue. Questo limite è dovuto al fatto che la modalità di aggiornamento usa un MemoryStream internamente per consentire la richiesta di ricerca durante l'aggiornamento di un archivio e MemoryStream ha un valore massimo uguale alla dimensione di un valore int.This limit is because update mode uses a MemoryStream internally to allow the seeking required when updating an archive, and MemoryStream has a maximum equal to the size of an int.

Si applica a