This browser is no longer supported.
  
    
  
   Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.
  
  
   Download Microsoft Edge
  
  
   More info about Internet Explorer and Microsoft Edge
  
  public:
 static void CreateFromDirectory(System::String ^ sourceDirectoryName, System::IO::Stream ^ destination);
  public static void CreateFromDirectory (string sourceDirectoryName, System.IO.Stream destination);
  static member CreateFromDirectory : string * System.IO.Stream -> unit
  Public Shared Sub CreateFromDirectory (sourceDirectoryName As String, destination As Stream)
  
   Parameters
  
  
   ArgumentException
  
  
   
    sourceDirectoryName
   
   is
   
    Empty
   
   , contains only white space, or contains at least one invalid character.
  
  
   The
   
    destination
   
   stream does not support writing.
  
  
   Remarks
  
  
   The directory structure from the file system is preserved in the archive. If the directory is empty, an empty archive is created. This method overload does not include the base directory in the archive and does not allow you to specify a compression level. If you want to include the base directory or specify a compression level, call the
   
    CreateFromDirectory(String, Stream, CompressionLevel, Boolean)
   
   method overload. If a file in the directory cannot be added to the archive, the archive is left incomplete and invalid, and the method throws an
   
    IOException
   
   exception.
  
  public:
 static void CreateFromDirectory(System::String ^ sourceDirectoryName, System::String ^ destinationArchiveFileName);
  public static void CreateFromDirectory (string sourceDirectoryName, string destinationArchiveFileName);
  static member CreateFromDirectory : string * string -> unit
  Public Shared Sub CreateFromDirectory (sourceDirectoryName As String, destinationArchiveFileName As String)
  
   Parameters
  
  
   
    destinationArchiveFileName
   
   already exists.
  
  
   A file in the specified directory could not be opened.
  
  
   An I/O error occurred while opening a file to be archived.
  
  
   NotSupportedException
  
  
   
    sourceDirectoryName
   
   or
   
    destinationArchiveFileName
   
   contains an invalid format.
  
  
   The zip archive does not support writing.
  
  
   Examples
  
  
   This example shows how to create and extract a zip archive by using the
   
    ZipFile
   
   class. It compresses the contents of a folder into a zip archive, and then extracts that content to a new folder. To use the
   
    ZipFile
   
   class, you must reference the
   
    System.IO.Compression.FileSystem
   
   assembly in your project.
  
  using System;
using System.IO.Compression;
class Program
    static void Main(string[] args)
        string startPath = @".\start";
        string zipPath = @".\result.zip";
        string extractPath = @".\extract";
        ZipFile.CreateFromDirectory(startPath, zipPath);
        ZipFile.ExtractToDirectory(zipPath, extractPath);
open System.IO.Compression
let startPath = @".\start"
let zipPath = @".\result.zip"
let extractPath = @".\extract"
ZipFile.CreateFromDirectory(startPath, zipPath)
ZipFile.ExtractToDirectory(zipPath, extractPath)
Imports System.IO.Compression
Module Module1
    Sub Main()
        Dim startPath As String = ".\start"
        Dim zipPath As String = ".\result.zip"
        Dim extractPath As String = ".\extract"
        ZipFile.CreateFromDirectory(startPath, zipPath)
        ZipFile.ExtractToDirectory(zipPath, extractPath)
    End Sub
End Module
    	Remarks
    	The directory structure from the file system is preserved in the archive. If the directory is empty, an empty archive is created. This method overload does not include the base directory in the archive and does not allow you to specify a compression level. If you want to include the base directory or specify a compression level, call the CreateFromDirectory(String, String, CompressionLevel, Boolean) method overload.
If the archive already exists, an IOException exception is thrown. If an entry with the specified name already exists in the archive, a second entry is created with an identical name.
If a file in the directory cannot be added to the archive, the archive is left incomplete and invalid, and the method throws an IOException exception.
	public:
 static void CreateFromDirectory(System::String ^ sourceDirectoryName, System::IO::Stream ^ destination, System::IO::Compression::CompressionLevel compressionLevel, bool includeBaseDirectory);
	public static void CreateFromDirectory (string sourceDirectoryName, System.IO.Stream destination, System.IO.Compression.CompressionLevel compressionLevel, bool includeBaseDirectory);
	static member CreateFromDirectory : string * System.IO.Stream * System.IO.Compression.CompressionLevel * bool -> unit
	Public Shared Sub CreateFromDirectory (sourceDirectoryName As String, destination As Stream, compressionLevel As CompressionLevel, includeBaseDirectory As Boolean)
	Parameters
			    ArgumentException
		    sourceDirectoryName is Empty, contains only white space, or contains at least one invalid character.
The destination stream does not support writing.
    	Remarks
    	The directory structure from the file system is preserved in the archive. If the directory is empty, an empty archive is created. Use this method overload to specify the compression level and whether to include the base directory in the archive. If a file in the directory cannot be added to the archive, the archive is left incomplete and invalid, and the method throws an IOException exception.
	public:
 static void CreateFromDirectory(System::String ^ sourceDirectoryName, System::String ^ destinationArchiveFileName, System::IO::Compression::CompressionLevel compressionLevel, bool includeBaseDirectory);
	public static void CreateFromDirectory (string sourceDirectoryName, string destinationArchiveFileName, System.IO.Compression.CompressionLevel compressionLevel, bool includeBaseDirectory);
	static member CreateFromDirectory : string * string * System.IO.Compression.CompressionLevel * bool -> unit
	Public Shared Sub CreateFromDirectory (sourceDirectoryName As String, destinationArchiveFileName As String, compressionLevel As CompressionLevel, includeBaseDirectory As Boolean)
	Parameters
		    destinationArchiveFileName already exists.
A file in the specified directory could not be opened.
An I/O error occurred while opening a file to be archived.
			    NotSupportedException
		    sourceDirectoryName or destinationArchiveFileName contains an invalid format.
The zip archive does not support writing.
  Examples
    	This example shows how to create and extract a zip archive by using the ZipFile class. It compresses the contents of a folder into a zip archive, and then extracts that content to a new folder. When compressing the archive, the base directory is included and the compression level is set to emphasize the speed of the operation over efficiency. To use the ZipFile class, you must reference the System.IO.Compression.FileSystem assembly in your project.
using System;
using System.IO;
using System.IO.Compression;
namespace ConsoleApplication
    class Program
        static void Main(string[] args)
            string startPath = @"c:\example\start";
            string zipPath = @"c:\example\result.zip";
            string extractPath = @"c:\example\extract";
            ZipFile.CreateFromDirectory(startPath, zipPath, CompressionLevel.Fastest, true);
            ZipFile.ExtractToDirectory(zipPath, extractPath);
open System.IO.Compression
let startPath = @"c:\example\start"
let zipPath = @"c:\example\result.zip"
let extractPath = @"c:\example\extract"
ZipFile.CreateFromDirectory(startPath, zipPath, CompressionLevel.Fastest, true)
ZipFile.ExtractToDirectory(zipPath, extractPath)
Imports System.IO
Imports System.IO.Compression
Module Module1
    Sub Main()
        Dim startPath As String = "c:\example\start"
        Dim zipPath As String = "c:\example\result.zip"
        Dim extractPath As String = "c:\example\extract"
        ZipFile.CreateFromDirectory(startPath, zipPath, CompressionLevel.Fastest, True)
        ZipFile.ExtractToDirectory(zipPath, extractPath)
    End Sub
End Module
    	Remarks
    	The directory structure from the file system is preserved in the archive. If the directory is empty, an empty archive is created. Use this method overload to specify the compression level and whether to include the base directory in the archive.
If the archive already exists, an IOException exception is thrown. If an entry with the specified name already exists in the archive, a second entry is created with an identical name.
If a file in the directory cannot be added to the archive, the archive is left incomplete and invalid, and the method throws an IOException exception.
	public:
 static void CreateFromDirectory(System::String ^ sourceDirectoryName, System::IO::Stream ^ destination, System::IO::Compression::CompressionLevel compressionLevel, bool includeBaseDirectory, System::Text::Encoding ^ entryNameEncoding);
	public static void CreateFromDirectory (string sourceDirectoryName, System.IO.Stream destination, System.IO.Compression.CompressionLevel compressionLevel, bool includeBaseDirectory, System.Text.Encoding? entryNameEncoding);
	static member CreateFromDirectory : string * System.IO.Stream * System.IO.Compression.CompressionLevel * bool * System.Text.Encoding -> unit
	Public Shared Sub CreateFromDirectory (sourceDirectoryName As String, destination As Stream, compressionLevel As CompressionLevel, includeBaseDirectory As Boolean, entryNameEncoding As Encoding)
	Parameters
			    ArgumentException
		    sourceDirectoryName is Empty, contains only white space, or contains at least one invalid character.
The destination stream does not support writing.
    	Remarks
    	The directory structure from the file system is preserved in the archive. If the directory is empty, an empty archive is created. Use this method overload to specify the compression level and character encoding, and whether to include the base directory in the archive. If a file in the directory cannot be added to the archive, the archive is left incomplete and invalid, and the method throws an IOException exception.
	public:
 static void CreateFromDirectory(System::String ^ sourceDirectoryName, System::String ^ destinationArchiveFileName, System::IO::Compression::CompressionLevel compressionLevel, bool includeBaseDirectory, System::Text::Encoding ^ entryNameEncoding);
	public static void CreateFromDirectory (string sourceDirectoryName, string destinationArchiveFileName, System.IO.Compression.CompressionLevel compressionLevel, bool includeBaseDirectory, System.Text.Encoding entryNameEncoding);
	public static void CreateFromDirectory (string sourceDirectoryName, string destinationArchiveFileName, System.IO.Compression.CompressionLevel compressionLevel, bool includeBaseDirectory, System.Text.Encoding? entryNameEncoding);
	static member CreateFromDirectory : string * string * System.IO.Compression.CompressionLevel * bool * System.Text.Encoding -> unit
	Public Shared Sub CreateFromDirectory (sourceDirectoryName As String, destinationArchiveFileName As String, compressionLevel As CompressionLevel, includeBaseDirectory As Boolean, entryNameEncoding As Encoding)
	Parameters
			    ArgumentException
		    sourceDirectoryName or destinationArchiveFileName is Empty, contains only white space, or contains at least one invalid character.
entryNameEncoding is set to a Unicode encoding other than UTF-8.
		    destinationArchiveFileName already exists.
A file in the specified directory could not be opened.
An I/O error occurred while opening a file to be archived.
			    NotSupportedException
		    sourceDirectoryName or destinationArchiveFileName contains an invalid format.
The zip archive does not support writing.
    	Remarks
    	The directory structure from the file system is preserved in the archive. If the directory is empty, an empty archive is created. Use this method overload to specify the compression level and character encoding, and whether to include the base directory in the archive.
If the archive already exists, an IOException exception is thrown. If an entry with the specified name already exists in the archive, a second entry is created with an identical name.
If a file in the directory cannot be added to the archive, the archive is left incomplete and invalid, and the method throws an IOException exception.
If entryNameEncoding is set to a value other than null, the entry names and comments are encoded by using the specified encoding. If the specified encoding is a UTF-8 encoding, the language encoding flag (in the general-purpose bit flag of the local file header) is set for each entry.
If entryNameEncoding is set to null, the entry names and comments are encoded according to the following rules:
For entry names and comments that contain characters outside the ASCII range, the language encoding flag is set, and UTF-8 is used to encode the entry name and comment.
For entry names and comments that contain only ASCII characters, the language encoding flag is not set, and the current system default code page is used to encode the entry names and comments.