Os arquivos Excel (XLS, [XLSX][2] e [PDF][3] estão entre os formatos de documento amplamente usados em quase todos os negócios. Para esses arquivos comumente usados, há muitos cenários nos quais precisa converter um arquivo em outro formato.Neste artigo, aprenderemos diferentes maneiras de como converter planilhas do Excel em formato PDF usando C# com aplicativos .NET.

Converter planilha do Excel para PDF usando C#
  • [.NET API para conversão de arquivos do Excel para PDF][4]
  • [Conversão de planilhas do Excel para PDF][5]
  • [Sequência de planilhas do Excel para conversão de PDF][6]
  • [Lista específica de planilhas do Excel para conversão de PDF][7]
  • [Converter o intervalo de células selecionado da planilha do Excel para PDF][8]

.NET API para conversão de arquivos do Excel em PDF

[GroupDocs.Conversion][9] fornece APIs que permitem que os arquivos do Excel sejam convertidos para o formato PDF em aplicativos .NET. Neste artigo, usaremos [GroupDocs.Conversion for .NET][10] para converter os dados dos arquivos Excel XLS/XLSX em formato PDF. Além disso, a API suporta a conversão de muitos outros formatos de arquivo, como documentos de processamento de texto, planilhas, apresentações, eBooks, imagens, etc., mencionados na [documentação][11].

Você pode baixar o instalador DLLs ou MSI da [seção de downloads][12] ou instalar a API em seu aplicativo .NET por meio do [NuGet][13].

PM> Install-Package GroupDocs.Conversion

Converter planilhas do Excel para PDF - C#

As etapas a seguir convertem a pasta de trabalho completa (todas as planilhas) para o formato PDF usando C#.

  • Prepare as opções de carregamento usando [SpreadsheetLoadOptions][14].
  • Carregue a planilha do Excel usando [Converter][15].
  • Chame o método [Convert()][16] usando [PdfConvertOptions][17] para converter todas as planilhas e salvá-las no formato PDF.

Veja a seguir o código-fonte C# sobre como converter a pasta de trabalho completa do Excel em PDF no aplicativo .NET.

/*
 * Converta todas as planilhas do Excel para o formato PDF usando C#
 */
// Preparar opções de carregamento e intervalo para o arquivo XLSX de origem
Func<LoadOptions> loadOptions = () => new SpreadsheetLoadOptions
{
    OnePagePerSheet = true
};
using (var converter = new GroupDocs.Conversion.Converter(@"path/spreadsheet.xlsx", loadOptions))
{
    // Converta e salve a planilha em formato PDF
    converter.Convert(@"path/all-sheets-converted.pdf", new PdfConvertOptions());
}
Converter PDF de dados do Excel

Sequência de conversão de planilhas do Excel para PDF - C#

Nem sempre é necessário transformar a pasta de trabalho completa. Também podemos converter qualquer número consecutivo de folhas. A seguir estão as etapas para converter qualquer subsequência da(s) planilha(s) da pasta de trabalho do Excel em formato PDF usando C#.

  • Carregue o arquivo Excel usando o [Converter][18].
  • Defina as opções de conversão usando [PdfConvertOptions][19].
  • Defina o número da folha inicial e o número de outras folhas na sequência.
  • Chame o método [Convert()][20] com as opções conversion para obter o subconjunto de planilhas em sequência salva no formato PDF.

A seguir está o código-fonte C# que converte as planilhas em sequência, ou seja, números de planilha 2,3 e 4 em PDF dentro do aplicativo .NET.

/*
 * Converter sequência de planilhas do Excel para formato PDF usando C#
 */
using (var converter = new GroupDocs.Conversion.Converter(@"path/spreadsheet.xlsx"))
{
    // Defina o número da folha inicial e a contagem consecutiva de folhas
    var convertOptions = new PdfConvertOptions()
    {
        PageNumber = 2,
        PagesCount = 3
    };
    // Converta e salve a planilha em formato PDF
    converter.Convert(@"path/sequential-sheets-converted.pdf", convertOptions);
}

Folhas de Excel específicas para conversão de PDF - C#

Podemos simplesmente fornecer a lista dos números das folhas para a conversão de folhas específicas. A seguir estão as etapas de como converter qualquer lista específica de números de planilha em formato PDF usando C#.

  • Carregue o arquivo de planilha usando o [Converter][21].
  • Selecione os números das folhas e defina como lista usando [PdfConvertOptions][22].
  • Chame o método [Convert()][23] com as opções de conversão para converter as planilhas listadas em formato PDF.

O trecho de código C# a seguir converte os números de planilha 1, 3 e 5 em PDF no aplicativo .NET.

/*
 * Converta a lista especificada de planilhas do Excel para o formato PDF usando C#
 */
using (var converter = new GroupDocs.Conversion.Converter(@"path/spreadsheet.xlsx"))
{
    // Defina a lista para números de planilhas na conversão
    var convertOptions = new PdfConvertOptions()
    {
        Pages = new System.Collections.Generic.List<int> { 1,3,5}
    };
    // Converta e salve a planilha em formato PDF
    converter.Convert(@"path/selected-sheets-conversion.pdf", convertOptions);
}

Converter o intervalo de células selecionado da planilha do Excel em PDF - C

Por último, mas não menos importante, na verdade, o mais complicado, também podemos converter qualquer intervalo de células de planilhas do Excel de maneira quase semelhante a outras abordagens. A seguir estão as etapas para converter qualquer intervalo de células de planilha(s) da pasta de trabalho em formato PDF usando C#.

  • Em primeiro lugar, defina o intervalo de células para conversão usando [SpreadsheetLoadOptions][24].
  • Carregue o arquivo de planilha usando o [Converter][25].
  • Selecione as folhas pelos números exatos das folhas ou pela subsequência usando [PdfConvertOptions][26].
  • Chame o método [Convert()][27] com as opções de conversão para converter o intervalo de células selecionado das planilhas selecionadas em formato PDF.

O código a seguir converte o intervalo de células (A1:C20) dos números de planilha 2, 3 e 4 para o formato PDF usando C#.

/*
 * Converta o intervalo de células especificado de planilhas do Excel especificadas para o formato PDF usando C#
 */
// Preparar opções de carregamento e intervalo para o arquivo XLSX de origem
Func<LoadOptions> loadOptions = () => new SpreadsheetLoadOptions
{
    ConvertRange = "A1:C20"
};
using (var converter = new Converter(@"path/spreadsheet.xlsx", loadOptions))
{
    var convertOptions = new PdfConvertOptions()
    {
        PageNumber = 2,
        PagesCount = 3
        // Páginas = new System.Collections.Generic.List<int> { 2,3,4}
    };
    // Salvar como PDF após a conversão
    converter.Convert(@"path/cell-range-converted.pdf", convertOptions);
}

Conclusão

Para concluir, aprendemos diferentes maneiras de converter planilhas do Excel em formato PDF usando C#. Primeiramente, procuramos converter a pasta de trabalho completa para o formato PDF, depois convertemos a subsequência de planilhas. Mais tarde, aprendemos como converter qualquer planilha fornecendo a lista de números exatos de planilha e, por último, obtivemos o arquivo PDF do intervalo de células selecionado da(s) planilha(s).

Saiba mais sobre as APIs GroupDocs.Conversion na [documentação][28]. Para dúvidas, entre em contato conosco através do [fórum][29].

Veja também

  • [Converter planilha do Excel para CSV e vice-versa em C#][30]
  • [Planilhas Excel com marca d’água usando C#][31]
  • [Arquivos PDF com marca d’água usando C#][32]
  • [Converter documentos para Excel (XLS, XLSX) em C#][33]

[2]: https://docs.fileformat.com/spreadsheet/xlsx/) [3]: https://docs.fileformat.com/pdf/ [4]: #excel-conversion-dotnet-api [5]: #excel-to-pdf [6]: #sheets-sequence-to-pdf [7]: #list-of-sheets-to-pdf [8]: #cell-ranges-to-pdf [9]: https://products.groupdocs.com/conversion/ [10]: https://products.groupdocs.com/conversion/net/ [11]: https://docs.groupdocs.com/conversion/net/supported-document-formats/ [12]: https://downloads.groupdocs.com/conversion [13]: https://www.nuget.org/packages/groupdocs.conversion [14]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion.options.load/spreadsheetloadoptions [15]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion/converter [16]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion/converter/methods/convert/index [17]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion.options.convert/pdfconvertoptions [18]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion/converter [19]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion.options.convert/pdfconvertoptions [20]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion/converter/methods/convert/index [21]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion/converter [22]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion.options.convert/pdfconvertoptions [23]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion/converter/methods/convert/index [24]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion.options.load/spreadsheetloadoptions [25]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion/converter [26]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion.options.convert/pdfconvertoptions [27]: https://apireference.groupdocs.com/conversion/net/groupdocs.conversion/converter/methods/convert/index [28]: https://docs.groupdocs.com/conversion [29]: https://forum.groupdocs.com/ [30]: https://blog.groupdocs.com/pt/2021/08/18/convert-excel-xls-xlsx-and-csv-in-csharp/ [31]: https://blog.groupdocs.com/pt/2021/11/04/watermark-excel-sheets-using-csharp/ [32]: https://blog.groupdocs.com/pt/2021/07/27/watermark-pdf-files-using-csharp/ [33]: https://blog.groupdocs.com/pt/2021/04/13/convert-document-to-excel-xls-xlsx-in-csharp/