Compartir a través de


Cómo: Excluir archivos de la compilación

En un archivo de proyecto, se pueden utilizar comodines para incluir todos los archivos de un directorio o un conjunto de directorios anidado como entradas para una compilación.Sin embargo, es posible que exista un archivo en el directorio o un directorio en el conjunto de directorios anidado que no se desee incluir como entrada para una compilación.Dicho archivo o directorio se puede excluir explícitamente de la lista de entradas.También es posible que exista un archivo en un proyecto que sólo se desee incluir con determinadas condiciones.Se pueden declarar explícitamente las condiciones para incluir un archivo en una compilación.

Excluir un archivo o directorio de las entradas para una compilación

Las listas de elementos son los archivos de entrada de una compilación.Los elementos que se desean incluir se declaran, de forma independiente o como grupo, usando el atributo Include.Por ejemplo:

<CSFile Include="Form1.cs"/>
<CSFile Include ="File1.cs;File2.cs"/>
<CSFile Include="*.cs"/>
<JPGFile Include="Images\**\*.jpg"/>

Si se han utilizado comodines para incluir todos los archivos de un directorio o un conjunto de directorios anidado como entradas para una compilación, es posible que haya uno o varios archivos en el directorio o un directorio en el conjunto anidado que no se desee incluir.Para excluir un elemento de la lista de elementos, utilice el atributo Exclude.

Para incluir todos los archivos .cs o .vb excepto Form2

  • Utilice uno de los atributos Include y Exclude siguientes:

    <CSFile Include="*.cs" Exclude="Form2.cs"/>
    

    -O bien-

    <VBFile Include="*.vb" Exclude="Form2.vb"/>
    

Para incluir todos los archivos .cs o .vb excepto Form2 y Form3

  • Utilice uno de los atributos Include y Exclude siguientes:

    <CSFile Include="*.cs" Exclude="Form2.cs;Form3.cs"/>
    

    -O bien-

    <VBFile Include="*.vb" Exclude="Form2.vb;Form3.vb"/>
    

Para incluir todos los archivos .jpg en subdirectorios del directorio Images, excepto los que se encuentran en el directorio Version2

  • Utilice los atributos Include y Exclude siguientes:

    <JPGFile
        Include="Images\**\*.jpg"
        Exclude = "Images\**\Version2\*.jpg"/>
    

    [!NOTA]

    Debe especificar la ruta de acceso de ambos atributos.Si utiliza una ruta de acceso absoluta para especificar las ubicaciones de los archivos en el atributo Include, también debe utilizar una ruta de acceso absoluta en el atributo Exclude; si utiliza una ruta relativa en el atributo Include, también debe utilizar una ruta relativa en el atributo Exclude.

Utilizar condiciones para excluir un archivo o directorio de las entradas para una compilación

Si existen elementos que se desean incluir, por ejemplo, en una versión de depuración pero no en una versión de lanzamiento, se puede utilizar el atributo Condition para especificar las condiciones en las que incluir el elemento.

Para incluir el archivo Formula.vb sólo en versiones de lanzamiento (release)

  • Utilice un atributo Condition similar al siguiente:

    <Compile
        Include="Formula.vb"
        Condition=" '$(Configuration)' == 'Release' " />
    

Ejemplo

En el ejemplo de código siguiente se compila un proyecto con todos los archivos .cs en el directorio excepto Form2.cs.

<Project DefaultTargets="Compile"
    xmlns="https://schemas.microsoft.com/developer/msbuild/2003" >

    <PropertyGroup>
        <builtdir>built</builtdir>
    </PropertyGroup>

    <ItemGroup>
        <CSFile Include="*.cs Exclude="Form2.cs"/>

        <Reference Include="System.dll"/>
        <Reference Include="System.Data.dll"/>
        <Reference Include="System.Drawing.dll"/>
        <Reference Include="System.Windows.Forms.dll"/>
        <Reference Include="System.XML.dll"/>
    </ItemGroup>

    <Target Name="PreBuild">
        <Exec Command="if not exist $(builtdir) md $(builtdir)"/>
    </Target>

    <Target Name="Compile" DependsOnTargets="PreBuild">
        <Csc Sources="@(CSFile)"
            References="@(Reference)"
            OutputAssembly="$(builtdir)\$(MSBuildProjectName).exe"
            TargetType="exe" />
    </Target>
</Project>

Vea también

Tareas

Cómo: Seleccionar los archivos que se van a compilar

Conceptos

Elementos de MSBuild

Otros recursos

MSBuild